商城网站建设公司价格,wordpress微信域名回调,广州seo网站推广公司,微信官网网站模板下载安装在java多线程程序中#xff0c;所有线程都不允许抛出未捕获的checked exception#xff0c;也就是说各个线程需要自己把自己的checked exception处理掉。这一点是通过java.lang.Runnable.run()方法声明(因为此方法声明上没有throws exception部分)进行了约束。但是线程依然有… 在java多线程程序中所有线程都不允许抛出未捕获的checked exception也就是说各个线程需要自己把自己的checked exception处理掉。这一点是通过java.lang.Runnable.run()方法声明(因为此方法声明上没有throws exception部分)进行了约束。但是线程依然有可能抛出unchecked exception当此类异常跑抛出时线程就会终结而对于主线程和其他线程完全不受影响且完全感知不到某个线程抛出的异常(也是说完全无法catch到这个异常)。JVM的这种设计源自于这样一种理念“线程是独立执行的代码片断线程的问题应该由线程自己来解决而不要委托到外部。”基于这样的设计理念在Java中线程方法的异常无论是checked还是unchecked exception都应该在线程代码边界之内run方法内进行try catch并处理掉. public class ExeceptionThread implements Runnable {Overridepublic void run() {throw new RuntimeException();}public static void main(String[] args) {try {ExecutorService exec Executors.newCachedThreadPool();exec.execute(new ExeceptionThread());} catch (Exception e) { //捕获不了System.out.println(exeception has handled);}}
} Exception in thread pool-1-thread-1 java.lang.RuntimeExceptionat Thread.Exection.ExeceptionThread.run(ExeceptionThread.java:10)at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)at java.lang.Thread.run(Unknown Source) 但如果线程确实没有自己try catch某个unchecked exception而我们又想在线程代码边界之外run方法之外来捕获和处理这个异常的话java为我们提供了一种线程内发生异常时能够在线程代码边界之外处理异常的回调机制即Thread对象提供的setUncaughtExceptionHandler(Thread.UncaughtExceptionHandler eh)方法。 通过该方法给某个thread设置一个UncaughtExceptionHandler可以确保在该线程出现异常时能通过回调UncaughtExceptionHandler接口的public void uncaughtException(Thread t, Throwable e) 方法来处理异常这样的好处或者说目的是可以在线程代码边界之外Thread的run()方法之外有一个地方能处理未捕获异常。但是要特别明确的是虽然是在回调方法中处理异常但这个回调方法在执行时依然还在抛出异常的这个线程中另外还要特别说明一点如果线程是通过线程池创建线程异常发生时UncaughtExceptionHandler接口不一定会立即回调。 class ExceptionThread2 implements Runnable {public void run() {Thread t Thread.currentThread();System.out.println(run() by t);System.out.println(eh t.getUncaughtExceptionHandler());throw new RuntimeException();}
}class MyUncaughtExceptionHandler implements Thread.UncaughtExceptionHandler {Overridepublic void uncaughtException(Thread t, Throwable e) {System.out.println(caught e);}
}class HandlerThreadFactory implements ThreadFactory {Overridepublic Thread newThread(Runnable r) {System.out.println(this creating new Thread);Thread t new Thread(r);System.out.println(created t ID: t.getId());t.setUncaughtExceptionHandler(new MyUncaughtExceptionHandler());System.out.println(eh t.getUncaughtExceptionHandler());return t;}
}public class CaptureUncaughtException {public static void main(String[] args) {ExecutorService exec Executors.newCachedThreadPool(new HandlerThreadFactory());exec.execute(new ExceptionThread2());}
} Thread.Exection.HandlerThreadFactory4e25154f creating new Thread
created Thread[Thread-0,5,main] ID:9
ehThread.Exection.MyUncaughtExceptionHandler70dea4e
run() by Thread[Thread-0,5,main]
ehThread.Exection.MyUncaughtExceptionHandler70dea4e
Thread.Exection.HandlerThreadFactory4e25154f creating new Thread
created Thread[Thread-1,5,main] ID:11
ehThread.Exection.MyUncaughtExceptionHandler193fa958
caught java.lang.RuntimeException 默认方式 public class SettingDefaultHandler {public static void main(String[] args) {Thread.setDefaultUncaughtExceptionHandler(new MyUncaughtExceptionHandler());//线程默认异常捕获器类ExecutorService execExecutors.newCachedThreadPool();exec.execute(new ExceptionThread2());}
} run() by Thread[pool-1-thread-1,5,main]
ehjava.lang.ThreadGroup[namemain,maxpri10]
caught java.lang.RuntimeException 比之上述方法还有一种编程上的处理方式可以借鉴即有时候主线程的调用方可能只是想知道子线程执行过程中发生过哪些异常而不一定会处理或是立即处理那么发起子线程的方法可以把子线程抛出的异常实例收集起来作为一个Exception的List返回给调用方由调用方来根据异常情况决定如何应对。不过要特别注意的是此时子线程早以终结。 Java thread里面关于异常的部分比较奇特。一般在线程里碰到checked exception推荐的做法是采用try/catch块来处理。而对于unchecked exception比较合理的方式是注册一个实现UncaughtExceptionHandler接口的对象实例来处理。 参考http://www.cnblogs.com/zhuawang/p/3751875.html http://blog.csdn.net/bluishglc/article/details/8216824转载于:https://www.cnblogs.com/onlysun/p/4601430.html