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!

人工智能实验室
相关文章相关文章
  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

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

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...