Android 应用Crash Log在Logcat中消失的问题 threadid=1: thread exiting with uncaught exception

时间:2021-04-08 20:27:20

最近在调试应用的时候,发现应用Crash了 在Logcat中只能看到如下信息:

Java
123 12-28 12:33:26.790: D/AndroidRuntime(11175): Shutting down VM12-28 12:33:26.790: W/dalvikvm(11175): threadid=1: thread exiting with uncaught exception (group=0x414c0930)

看不到具体的异常堆栈信息了。而看不到具体堆栈信息了 ,解决Crash问题就非常困难了。
后来经过半天的排查,才发现原来项目中使用了百度地图定位SDK以及第三方统计SDK,而这两个SDK中都包含了一个功能:捕获未处理异常!

Java
1 Thread.setDefaultUncaughtExceptionHandler(locala);

例如 ,要使用百度定位SDK,您需要使用到com.baidu.location.f 这个Service, 而在这个Service的onCreate函数中有如下代码:

Java
12345   public void onCreate()  {    a locala = new a(this);    Thread.setDefaultUncaughtExceptionHandler(locala);    this.r = new c(this, this.P);


而Thread.UncaughtExceptionHandler 这个自定义的运行时异常处理类,把Androi系统的异常处理类给替代了,并且没有把异常信息输出到Logcat中,这样您就没法方便的调试应用了。
解决方式
创建一个自定义的Application类,在该类中定义一个静态属性来获取Android默认的 UncaughtExceptionHandler 。

public static final UncaughtExceptionHandler sUncaughtExceptionHandler = Thread
.getDefaultUncaughtExceptionHandler();

然后在项目中所有Activity、Service 的onCreate函数中添加如下一句:

Java
123     @Override    protectedvoidonCreate(BundlesavedInstanceState){        Thread.setDefaultUncaughtExceptionHandler(App.sUncaughtExceptionHandler);

,这样可以把Android默认的UncaughtExceptionHandler 给设置回来。

如果这样还是不行,那就在onResume函数中也设置一下。

这样就应该可以在LogCat中看到Crash Log。



Read more: http://blog.chengyunfeng.com/?p=460#ixzz4D0xczhYq