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

相关文章
相关标签/搜索