Java處理Exception無法捕獲的異常


場景

使用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)

 

 擴展閱讀

ExecutorService 的理解與使用

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM