android开发如何收集已发布程序的崩溃信息

  次阅读 来源:互联网(转载协议) 2016-01-19 12:16 我要评论(0)

下面我就说说如何收集程序运行过程的异常信息。需要的朋友可以过 来参考下

我们写程序的时候都希望能写出一个没有任何Bug的程序,期望在任何情况下都不会发生程序崩溃。不过理想是丰满的,现实是骨感的。没有一个程序员能 保证自己写的程序绝对不会出现异常崩溃。特别是针对用户数达到几十万几百万的程序,当你用户数达到一定数量级后,就算你的程序出现个别异常崩溃情况也不用 惊讶。

既然我们写的程序都有可能发生异常崩溃,如果是还没发布的程序,我们可以通过测试抓取Log来分析。不过针对已经发布的程序,我们没法重现现象,所以让用 户反馈程序异常信息就很重要。下面我们说说如何收集程序运行过程的异常信息。

1、Android异常捕获接口

复制代码 代码如下:

//当线程因未捕获的异常而突然终止时,调用处理程序的接口

static interface UncaughtExceptionHandler

2、设置线程捕获异常

从上面的接口我们可以看到,这个接口是针对线程来说,也就是说我们如果需要监控某个线程运行情况,只要把这个接口实现了,然后把监控方 法设置到具体的线程里面即可。一般来说,我们最需要监控的就是我们的UI线程也就是主线程。

复制代码 代码如下:

//设置当线程由于未捕获到异常而突然终止,并且没有为该线程定义其他处理程序时所调用的默认处理程序。

static void setDefaultUncaughtExceptionHandler(Thread.UncaughtExceptionHandler eh)

3、UncaughtExceptionHandler 实例

复制代码 代码如下:

class MythouCrashHandler implements UncaughtExceptionHandler

{

private static final String TAG = "MythouCrashHandler---->";

private UncaughtExceptionHandler defaultUEH;

//构造函数,获取默认的处理方法

public MythouCrashHandler()

{

this.defaultUEH = Thread.getDefaultUncaughtExceptionHandler();

}

//这个接口必须重写,用来处理我们的异常信息

@Override

public void uncaughtException(Thread thread, Throwable ex)

{

final Writer result = new StringWriter();

final PrintWriter printWriter = new PrintWriter(result);

//获取跟踪的栈信息,除了系统栈信息,还把手机型号、系统版本、编译版本的唯一标示

StackTraceElement[] trace = ex.getStackTrace();

StackTraceElement[] trace2 = new StackTraceElement[trace.length+3];

System.arraycopy(trace, 0, trace2, 0, trace.length);

trace2[trace.length+0] = new StackTraceElement("Android", "MODEL", android.os.Build.MODEL, -1);

trace2[trace.length+1] = new StackTraceElement("Android", "VERSION", android.os.Build.VERSION.RELEASE, -1);

trace2[trace.length+2] = new StackTraceElement("Android", "FINGERPRINT", android.os.Build.FINGERPRINT, -1);

//追加信息,因为后面会回调默认的处理方法

ex.setStackTrace(trace2);

ex.printStackTrace(printWriter);

//把上面获取的堆栈信息转为字符串,打印出来

String stacktrace = result.toString();

printWriter.close();

Log.e(TAG, stacktrace);

//这里把刚才异常堆栈信息写入SD卡的Log日志里面

本站部分文章来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • teamLab创始人猪子寿之: 抛去衣食住行,我还剩下什么?

    teamLab创始人猪子寿之: 抛去衣食住行,我还剩下什么?

  • Michael I. Jordan带你解读百万奖金ATEC蚂蚁人工智能大赛

    Michael I. Jordan带你解读百万奖金ATEC蚂蚁人工智能大赛

  • Oculus公布原型机,大幅度提升可视角,能实现140°的视场水平

    Oculus公布原型机,大幅度提升可视角,能实现140°的视场水平

  • 2018深圳国际人工智能展览会 2018 shenzhen International Artif

    2018深圳国际人工智能展览会 2018 shenzhen International Artif

网友点评网友点评
阅读推荐阅读推荐

据外媒报道,STEER打造了首款完全自动驾驶停车技术,旨在使常规车辆转变为无人驾驶车辆。STEER的首款技术应用是4级自动驾驶及网络安全停车...

近日,美国软性机器抓手制造商 Soft Robotics 宣布,获得 2000 万美元的融资,本轮投资者包括 Scale Venture Partners,Calibrate Ventures...

据外媒报道,加州车管局发布了《2017自动驾驶脱离报告(California Autonomous Vehicle Disengagement Reports)》,其中谈及了脱离的具体...

用人机语音交互,来解决智能家居适老的问题;通过家庭门禁与安防套件、空气净化套件、可燃气体与有害气体监控套件等相互联动,在不同生活情...