最近在调试应用的时候,发现应用Crash了 在Logcat中只能看到如下信息:
看不到具体的异常堆栈信息了。而看不到具体堆栈信息了 ,解决Crash问题就非常困难了。
后来经过半天的排查,才发现原来项目中使用了百度地图定位SDK以及第三方统计SDK,而这两个SDK中都包含了一个功能:捕获未处理异常!
例如 ,要使用百度定位SDK,您需要使用到com.baidu.location.f 这个Service, 而在这个Service的onCreate函数中有如下代码:
而Thread.UncaughtExceptionHandler 这个自定义的运行时异常处理类,把Androi系统的异常处理类给替代了,并且没有把异常信息输出到Logcat中,这样您就没法方便的调试应用了。
解决方式
创建一个自定义的Application类,在该类中定义一个静态属性来获取Android默认的 UncaughtExceptionHandler 。
public static final UncaughtExceptionHandler sUncaughtExceptionHandler = Thread
.getDefaultUncaughtExceptionHandler();
然后在项目中所有Activity、Service 的onCreate函数中添加如下一句:
,这样可以把Android默认的UncaughtExceptionHandler 给设置回来。
如果这样还是不行,那就在onResume函数中也设置一下。
这样就应该可以在LogCat中看到Crash Log。
Read more: http://blog.chengyunfeng.com/?p=460#ixzz4D0xczhYq