Java獲取e.printStackTrace()打印的信息方式

獲取e.printStackTrace()打印的信息

某些情況下,我們需要獲取應用打印的異常信息,這時就可以借助StringWriter和PrintWriter兩個類來獲取異常信息

具體用法如下:

        try{
            throw new NullPointerException();
        }catch (Exception e){
            StringWriter sw = new StringWriter();
            e.printStackTrace(new PrintWriter(sw,true));
            String infomsg = sw.toString();
            System.out.println(infomsg);
        }

e和e.printStackTrace()方法

e初始化,也就是實例化Exception類型的對象,e是此對象引用名稱。然後e(引用)會自動調用Exception類中指定的方法,也就出現瞭e.printStackTrace()。

當然,我們也可以用System語句輸出,那麼這兩個語句有什麼區別呢?

1、兩個輸出語句都能輸出

System語句可以提示你異常發生的位置;但e.printStackTrace()可以顯示更深的調用關系。

例如:程序中有繼承的關系

Rose extends Flower ; Flower extends Plant;假如我們在創建 Rose

的時候發生異常,那麼System語句就會輸出異常 at Rose ,然後向外層輸出

但e.printStackTrace()輸出除瞭標準異常外,打印 at Plant at Flower at Rose

…….再向外層調查。 在向外層調查的情況下,都一樣

2、System.out.println();

當發生異常時顯示你自己設定的字符串信息;e.printStackTrace();是打印異常的堆棧信息,指明錯誤原因。

note:其實當發生異常時,通常要處理異常,這是編程的好習慣,所以e.printStackTrace()可以方便你調試程序!

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。

推薦閱讀: