今天编程时候遇到一个问题:
W/dalvikvm: threadid=1: thread exiting with uncaught exception (group=0x419b4c50) 。。。。 log完全没有,,,这个时候有心杀贼,无力回天啊,,,,什么报错信息都没有。 百度各种问题解决方案,最终有一篇文章:http://blog.csdn.net/liqiangeastsun/article/details/43986605 讲了一个解决问题的方案: 以下是原文:Android错误threadid=1: thread exiting with uncaught exception (group=0x416298c8)
在项目开发中测试时崩溃,错误如上 该错误的意思是线程中存在没有捕获到的异常。一般情况下捕获异常使用
try { } catch (Exception e) { } 123456 123456但是在线程池中,线程池在执行任务时捕获了所有异常,这样一来线程中所有的异常都无法捕获到抛出的异常。 即 try catch 捕获不到异常了。 Java中有一个接口,UncaughtExceptionHandler 描述如下:
static interface Thread.UncaughtExceptionHandler // 当 Thread 因未捕获的异常而突然终止时,调用处理程序的接口。 12 12Thread类中的一个方法
static void setDefaultUncaughtExceptionHandler(Thread.UncaughtExceptionHandler eh) //设置当线程由于未捕获到异常而突然终止,并且没有为该线程定义其他处理程序时所调用的默认处理程序。 123 123我们需要实现这样一个接口UncaughtExceptionHandler,然后在程序的主线程中设置处理程序。 代码如下
import java.lang.Thread.UncaughtExceptionHandler; //implements UncaughtExceptionHandler public class Other extends Activity implements UncaughtExceptionHandler { //必须实现接口uncaughtException @Override public void uncaughtException(Thread arg0, Throwable arg1) { //在此处理异常, arg1即为捕获到的异常 Log.i("AAA", "uncaughtException " + arg1); } } 12345678910111213141516 12345678910111213141516现在还无法捕获到线程中的异常,还需要调用一个方法
Thread.setDefaultUncaughtExceptionHandler(this); 1 1在OnCreate方法中调用一下即可
@Override protected void onCreate(Bundle savedInstanceState) { //在OnCreate方法中调用下面方法,然后再使用线程,就能在uncaughtException方法中捕获到异常 Thread.setDefaultUncaughtExceptionHandler(this); } 12345 12345完整代码如下
//导入包 import java.lang.Thread.UncaughtExceptionHandler; //implements UncaughtExceptionHandler public class Other extends Activity implements UncaughtExceptionHandler { @Override protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); setContentView(R.layout.th); //在此调用下面方法,才能捕获到线程中的异常 Thread.setDefaultUncaughtExceptionHandler(this); //获取创建的 Button btn1 = (Button) findViewById(R.id.btn); //给btn1添加一个点击监听事件 btn1.setOnClickListener(new OnClickListener() { @Override public void onClick(View arg0) { //调用我自己的方法 Init(); } }); } public void Init() { //开启线程 new Handler(Looper.getMainLooper()).post(new Runnable() { @Override public void run() { //此处的 try catch 是无法捕获到异常的 try { ////////////////////////////////////////// //需要在线程中调用的方法purchase.init(context, iapListener) purchase.init(context, iapListener); ////////////////////////////////////////// } catch (Exception e) { // TODO: handle exception Log.i("AAA", "INIG " + e); e.printStackTrace(); } } }); } //必须实现接口uncaughtException @Override public void uncaughtException(Thread arg0, Throwable arg1) { //在此处理异常, arg1即为捕获到的异常 Log.i("AAA", "uncaughtException " + arg1); } 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152这样再次运行就会捕获到线程中的异常,不会导致项目直接崩溃
最终可以打印出log信息了,报错为:(Android5.0以上没这个问题,5,0以下有问题的) java.lang.ClassCastException: android.view.ViewGroup$LayoutParams cannot be cast to android.widget.AbsListView$LayoutParams 问题已经很明显了,类强转时候报的问题: 解决方案: android.view.ViewGroup.LayoutParams 改为: android.widget.AbsListView.LayoutParams 这个问题到不是很关键,主要问题是找到了方法,当log不能显示异常信息时候,,,,可以帮我们打印出log信息,然后分析问题,解决问题。。。。