Android&iOS崩溃堆栈上报
Android&iOS崩溃堆栈上报
原文地址:http://www.cnblogs.com/songcf/p/4885468.html
通过崩溃捕获和收集,可以收集到已发布应用(游戏)的异常,以便开发人员发现和修改bug,对于提高软件质量有着极大的帮助。在这里总结一下这几天做崩溃捕获的收获。
我们项目使用的是cocos2dx-js,那么要捕获的信息就有以下三点:
- js脚本语法错误、js调用为定义的native对象(程序不会崩溃)
- iOS(obj-c)/Android(java)端的未捕获异常导致的crash
- c++操作时导致的crash
1. js端错误
js端的错误,都会调用2dx的ScriptingCore::reportError
方法打印日志,在该方法内获取错误并上报即可。
2. iOS(obj-c)/Android(java)的未捕获异常
iOS/Android都可以在程序的入口处设置未捕获异常的捕获
- iOS :
NSSetUncaughtExceptionHandler(&HandleException);
- Android :
Thread.setDefaultUncaughtExceptionHandler(handler);
在回调中获取堆栈信息上报即可。
3. c++层操作时导致crash
c++操作错误导致crash时,无论是iOS还是android系统,其底层都是unix或者是类unix系统,可以通过信号机制来捕获(signal或者是sigaction),即任何系统错误都会抛出一个错误信号,我们可以通过设定一个回调函数,然后在回调函数里面打印并发送错误日志,而我在接入时,主要的难点在Android平台。
下面列举一些我尝试过的,获取c/c++函数调用堆栈的方法
1)使用CallStack工具类
头文件位于frameworks/native/include/utils/CallStack.h
,在Android的C++中,已经集成了工具类CallStack,在libutils.so中。此方法不适用NDK,对于2dx来说,如果想要使用该工具类需要下载android源码,然后在ndk的工程中添加依赖;或者使用dlopen/dlsym动态获得函数句柄实现调用(该方法不知可行否,还没来得及测试)
2)使用execinfo.h
glibc头文件"execinfo.h"中的backtrace、backtrace_symbols接口是linux下常用的获取堆栈的方式,但是该方法不适用于android,因为android适用的是bionic,而非glibc。
3)使用unwind_backtrace
使用unwind在百度上能查出很多总不同的实现,这里贴出一篇我用过并成功编译运行的实现方式的帖子:http://stackoverflow.com/questions/8115192/android-ndk-getting-the-backtrace
但是该方式如果是在收到signal的回调函数中使用,是不能还原崩溃堆栈的,只能得到signal发出后到调用unwind之间的函数堆栈,而我们需要的是signal发出前的崩溃堆栈
4)通过函数调用原理,自己实现获取函数栈的方法
这里有篇不错的博客:http://hutaow.com/blog/2013/10/15/dump-stack/ 不过我在测试时,汇编代码ndk编译不过,一直没解决,所以并没有采用该方法。
后来又找到了一篇不错的文章,可以结合着看:http://blog.chinaunix.net/uid-24774106-id-3457205.html
5)android平台通过logcat获取崩溃堆栈
在收到信号时通过jni回调java端,通过新开一个进程获取logcat来得到崩溃堆栈,但此时并未得到c++的崩溃堆栈,该方法源自:
http://stackoverflow.com/questions/8115192/android-ndk-getting-the-backtrace#
http://www.cnblogs.com/lancidie/archive/2013/04/13/3019349.html
6)使用第三发sdk
使用第三方sdk很方便,而且在后台浏览crash信息也很清晰,这里推荐一下我用的tencent-bugly,如果你在使用之前不清楚获取崩溃堆栈的原理,看看前面几点提到的文章和方法会收益颇多
关于符号表的原理推荐看这本书:
《Linkers and Loaders》——John Levine
Android&iOS崩溃堆栈上报的更多相关文章
- 转: iOS崩溃堆栈符号表使用与用途
转:http://bugly.qq.com/blog/?p=119 iOS崩溃堆栈符号化,定位问题分分钟搞定! 2015.3.16 腾讯Bugly 微信分享 最近一段时间,在跟开发者沟通过程中,萝 ...
- 如何用ndk-stack察看android崩溃堆栈
前提:要打开eclipse的LogCat窗口 1.保存log,先要选中eclipse的LogCat的所有行,点击保存,假设保存到了/User/mac/Desktop/log.txt 2.找到你的so( ...
- 常用获取Android崩溃日志和IOS崩溃日志的几种方法
一:前言 在日常测试app时,经常会遇到崩溃问题,测试快速抓取到崩溃日志可以有效方便开发进行定位,快速解决问题所在测试做到测试分析,定位是非常重要的,这也是判断一个测试能力指标的一大维度. 二:And ...
- iOS 日志自动上报
您好,欢迎使用腾讯Bugly!腾讯Bugly是腾讯公司为移动开发者开放的服务之一. 针对移动应用,腾讯Bugly提供了专业的Crash(崩溃).Android ANR(application n ...
- iOS崩溃治理--开篇
去年我开始负责iOS崩溃治理的工作,从原来的万分之五崩溃率,一直到现在的万分之一左右的崩溃率,期间踩了很多坑,因此想和大家分享一下,希望能对大家有所帮助,也欢迎大家私信交流. 如果你打算开始治理崩溃的 ...
- iOS崩溃调试的使用和技巧总结
在iOS开发调试过程中以及上线之后,程序经常会出现崩溃的问题.简单的崩溃还好说,复杂的崩溃就需要我们通过解析Crash文件来分析了,解析Crash文件在iOS开发中是比较常见的. 现在网上有很多关于解 ...
- windows phone和android,ios的touch事件兼容
1.开发背景 最近用html5写了个小游戏,中间踩过无数坑,有很多甚至百度都百度不到答案,可见html5还真是不成熟,兼容性的复杂度比ie6有过之而无不及,性能那个渣简直无力吐槽.. 好了,吐槽结束, ...
- android app崩溃日志收集以及上传
源代码获取请到github:https://github.com/DrJia/AndroidLogCollector 已经做成sdk的形式,源代码已公开,源代码看不懂的请自行google. 假设想定制 ...
- iOS崩溃日志ips文件解析
iOS崩溃日志ips文件解析 一 简介 测试组的同事在进行稳定性测试时,通常会遇到一些崩溃,然后他们会将这些崩溃日志(一般是ips格式的文件)反馈给开发进行分析,但是这些ips文件中的内容通常是如下 ...
随机推荐
- Android NDK调试C++源码(转)
[原创文章,转载请保留或注明出处,http://download.csdn.net/download/bigmaxim/5474055] 1. 相关软件 adt-bundle-windows-x86. ...
- <<海闻电子发票接口 ESB 封装文档>>
<<海闻电子发票接口 ESB 封装文档>> 章节目录结构: 发票验证接口 发票开具接口 ESB请求地址: 发票验证接口: http://10.15.22.120:8866/42 ...
- USB -- scsi命令集
摘自:<圈圈教你玩usb> 241页 SCSI(small computer system interface)是小型计算机系统的缩写,有一套完整的协议规定其命令和命令数据的响应.scsi ...
- (博弈论)hdoj 1525 Euclid's Game
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1525 题目大意:Stan和Ollie在玩一个游戏,a和b两个数字,每次可以选择较大的数减去较小的数的若 ...
- java去掉jsp标签内容的方法
//去掉内容的标签 public static String removeTag(String count){ try { int tagCheck=-1; do { i ...
- vtk读取文件中点坐标[转]
vtk基础编程(2)-读取数据文件中的坐标点 1. 案例说明 在实际计算中,常常需要大量的数据, 这个时候数据文件就必不可少, 例如 数据文件points.dat, 中存放了三个点的坐标, 0.0 0 ...
- Apache开启伪静态后报500错误.
参考:http://blog.163.com/lgh_2002/blog/static/44017526201051452939761/ 加载Rewrite模块: 在conf目录下httpd.conf ...
- ASSER、VERIFY、TRACE详解
ASSERT()被测试它的参数,如果参数为零,则中断执行并打印一段说明消息.在Release版本的程序中它不起任何作用. ASSERT()使用的时候必须保证参数表达式中不能有函数调用,因此对于任何有函 ...
- C#常用类汇总
一.object常用类 1.获取去类的类型和公共属性 var a= new Class A(); var props = A.GetType().GetProperties();
- Thinkphp的Volist标签
Volist标签主要用于在模板中循环输出数据集或者多维数组. volist标签(循环输出数据) 闭合 非闭合标签 属性 name(必须):要输出的数据模板变量 id(必须):循环变量 offset(可 ...