java中的exception stack有時候不輸出的緣由(轉)

原文  https://www.cnblogs.com/lemonlotus/p/5650687.htmlhtml

有時候,咱們在看java錯誤日誌時,只看到一個java.lang.NullPointerException,卻沒有看到錯誤的棧,緣由是啓動時候有一項參數能夠選擇配置:OmitStackTraceInFastThrowjava

 

JVM 看不到某些異常的stacktrace問題
在java 1.5的release notes裏面能夠看到這樣一句話:jvm

The compiler in the server VM now provides correct stack backtraces for all "cold" built-in exceptions. For performance purposes, when such an exception is thrown a few times, the method may be recompiled. After recompilation, the compiler may choose a faster tactic using preallocated exceptions that do not provide a stack trace. To disable completely the use of preallocated exceptions, use this new flag: -XX:-OmitStackTraceInFastThrow.ide

大致的意思就是對於cold build-in exception jvm都會throw 沒有stacktrace的exception。從1.5開始提供了一個開關關閉此功能post

public class TestCompile {
private static final int count = 1000000;
/**
* @param args
*/
public static void main(String[] args)throws Exception {
int index = count;
while(index -- > 0){
try {
work();
} catch (Exception e) {
e.printStackTrace();
}
}
}
private static void work(){
String value = null;
value.length();
}
}優化


編譯後使用java -server -XX:-OmitStackTraceInFastThrow TestCompile 運行,發現一直都是相似ui

java.lang.NullPointerException
at TestCompile.work(TestCompile.java:25)
at TestCompile.main(TestCompile.java:17)this

的stacktrace。spa

換成java -server -XX:+OmitStackTraceInFastThrow TestCompile 運行一段時間後就會出現日誌

java.lang.NullPointerException
java.lang.NullPointerException
java.lang.NullPointerException
java.lang.NullPointerException
java.lang.NullPointerException
java.lang.NullPointerException
java.lang.NullPointerException
java.lang.NullPointerException
java.lang.NullPointerException

這樣的exception,說明stacktrace 該優化已經起做用。-XX:+OmitStackTraceInFastThrow選項在-server狀況下默認開啓。

這就不難解釋爲什麼常常在系統日誌中看到不少行的java.lang.NullPointerException 苦於找不到stacktrace而不知道錯誤出在何處。

 

遇到這種狀況,解決的方法也很簡單:既然在一段時間後jvm纔會進行從新編譯優化,那麼該錯誤在剛開始出現的時候仍是會有stacktrace的。因此向前搜索日誌,或者將程序重啓,觀察剛重啓時候的log即可以找到錯誤的stacktrace

最後注意的是,上述優化是針對all "cold" built-in exceptions ,不單單是NullPointerException

相關文章
相關標籤/搜索