android/java 主线程catch子线抛出的异常

做Android项目的时候发现调用 SUP访问网络的类会抛出异常导致程序崩溃 但是还不能catch到这个异常。很是郁闷 进过一番百度终于找到原因


以下来自网络------------------------------------------------------------------------------------------------------------

      而所有的具体线程都实现这个方法,所以这里就明确了一点,线程代码不能抛出任何checked异常。所有的线程中的checked异常都只能被线程本身消化掉。:)   这样本身也是符合线程的设计理念的,线程本身就是被看作独立的执行片断,它应该对自己负责,所以由它来消化所有的checked异常是很正常的。   
  这样就回答了楼主的第一个问题:checked异常一定要在线程内部消化。   
    
  但是,线程代码中是可以抛出错误(Error)和运行级别异常(RuntimeException)的。Error俺们可以忽略,因为通常Error是应该留给vm的,而RuntimeException确是比较正常的,如果在运行过程中满足了某种条件导致线程必须中断,可以选择使用抛出运行级别异常来处理,如下:   

  <<   
          public   void   run()   {   
                if   (...)   throw   new   RuntimeException();   
          }   
  >>   
  当线程代码抛出运行级别异常之后,线程会中断。:)这点java中解释得很清楚:   
  <<   @see   Thread   
  All   threads   that   are   not   daemon   threads   have   died,   either   by   returning   from   the   call   to   the   run   method   or   "by   throwing   an   exception   that   propagates   beyond   the   run   method".     
  >>   
  但是对于invoke此线程的主线程会产生什么影响呢?主线程不受这个影响,不会处理这个RuntimeException,而且根本不能catch到这个异常。会继续执行自己的代码   :)   
  所以得到结论:线程方法的异常只能自己来处理。主线程catch不到这个异常   
    
  关于最后一点,不相信的话大家可以做这么一个试验:   
  <<   
  public   class   TestThreadException   extends   Thread   {   
          public   void   run()   {   
                  throw   new   RuntimeException();   
          }   
    
          public   static   void   main(String[]   args)   throws   InterruptedException   {   
                  try   {   
                          new   TestThreadException().start();   
                  }   catch(RuntimeException   ex)   {   
                          //   看看能不能到达这里?   :)   
                  }   
                    
                  Thread.sleep(1000);   
                  //   看看能不能到达这里?   :)   
          }   
  }   
  >>  以上来自网络------------------------------------------------------------------------------------------------------------

  主线程捕获子线程抛出的异常 代码

   

public class TestThreadException {
    
	
	 public   static   void   main(String[]   args){   
         try   {   
        	 Thread.setDefaultUncaughtExceptionHandler(new JQCrashHandlerExt());
        	    new TestThread().start();    
             }   catch(RuntimeException   ex)   {   
                System.out.println("捕获到异常了--------------------");
         }   
           
         try {
			Thread.sleep(1000);
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}   
         System.out.println("主线程运行结束=================");
    }   
	 
	  
	 
}


 class  TestThread extends Thread{
	/* (non-Javadoc)
	 * @see java.lang.Thread#run()
	 */
	@Override
	public void run() {
		
		 System.out.println("子线程运行了-----------------------00000000000000000=============");
		 throw   new   RuntimeException();   
	}
}

public class JQCrashHandlerExt implements UncaughtExceptionHandler{

	/* (non-Javadoc)
	 * @see java.lang.Thread.UncaughtExceptionHandler#uncaughtException(java.lang.Thread, java.lang.Throwable)
	 */
	@Override
	public void uncaughtException(Thread t, Throwable e) {
		 System.out.println("捕获到 子线程 uncaught异常了--------------------------=============");
	}

}

猜你喜欢

转载自blog.csdn.net/NN955/article/details/37699271