场景:
使用try...catch(Exception e){}来捕获异常,执行过程中线程中断或阻塞了,但是catch块中却并没有捕获到异常信息。
try{ // 此处可能是调用一个远程的接口,或是调用了某个jar包中的方法。 // 此处出现了异常,线程中断或阻塞了,不再继续往下执行
}catch(Exception e){ e.printStackTrace(); // 此处却没有异常的信息出现 }
网搜到的解决办法原文:
来源于某个bbs地址:http://bbs.csdn.net/topics/390952122?locationNum=7
bbs中推荐网址:http://blog.csdn.net/trendgrucee/article/details/17656217
记录一下原文中的解决方案:
step1: 写一个异常处理类
为了解决线程意外终止,确无法捕获异常,无法判断原因。可以使用Thread.UncaughtExceptionHandler。
public class MyUncaughtExceptionHandler implements Thread.UncaughtExceptionHandler { @Override public void uncaughtException(Thread t, Throwable e) { // 打印出现异常的线程和异常名称 System.out.println("捕获到异常 : 线程名[" + t.getName() + "], 异常名[" + e + "]"); // 异常栈的信息 e.printStackTrace(); // TODO ... 如果对异常还需要做特殊处理,可以在此处继续实现处理方法 } }
step2:测试异常处理类是否可以捕获异常
2.1 先写一个会抛出异常的线程
public class ExceptionThread implements Runnable { @Override public void run() { // 线程信息 Thread t = Thread.currentThread(); System.out.println("执行线程:" + t); System.out.println("异常被谁处理:" + t.getUncaughtExceptionHandler()); // 抛出异常 throw new RuntimeException(); } }
2.2 测试类的main方法中设置线程的异常处理器,并执行会抛出异常的线程(异常处理器使用示例)
import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; public class SettingDefaultHandler { public static void main(String[] args) { // 设置线程的异常处理器 Thread.setDefaultUncaughtExceptionHandler(new MyUncaughtExceptionHandler()); // 执行会抛出异常的线程,看看是否会被捕获 ExecutorService exec = Executors.newCachedThreadPool(); exec.execute(new ExceptionThread()); } }
2.3 执行测试类main方法的打印信息
执行线程:Thread[pool-1-thread-1,5,main] 异常被谁处理:java.lang.ThreadGroup[name=main,maxpri=10] 捕获到异常 : 线程名[pool-1-thread-1], 异常名[java.lang.RuntimeException] java.lang.RuntimeException at com.envision.modules.liquid.myExceptionHandler.ExceptionThread.run(ExceptionThread.java:13) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) at java.lang.Thread.run(Thread.java:745)
扩展阅读: