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。
推薦閱讀:
- 一篇文章帶你瞭解Java泛型的super和extends
- 一文給你通俗易懂的講解Java異常
- java自定義異常以及throw和throws關鍵字用法
- java 異常之手動拋出與自動拋出的實例講解
- Java異常Exception詳細講解