引自:http://blog.csdn.net/alivetime/article/details/6166252#
在java 1.5的release notes里面可以看到这样一句话:
- 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.
大体的意思就是对于cold build-in exception jvm都会throw 没有stacktrace的exception。从1.5开始提供了一个开关关闭此功能
演示代码如下:
- /**
- * haitao-yao@Jan 27, 2011
- */
- 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 运行,发现一直都是类似
- java.lang.NullPointerException
- at TestCompile.work(TestCompile.java:25)
- at TestCompile.main(TestCompile.java:17)
的stacktrace。
换成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
好,祝大家玩儿的愉快。
Reference:
1. java 1.5 release notes: http://java.sun.com/j2se/1.5.0/relnotes.html#hotspot
2. jvm debugging options: http://www.oracle.com/technetwork/java/javase/tech/vmoptions-jsp-140102.html#DebuggingOptions
相关推荐
Thread Dump 是非常有用 Java应用问题的工具。每一个 Java 虚拟机 都有及时生成所有线程在某一点状态的 thread-dump 的能力,虽然各个 Java 虚拟机打印的thread dump 略有不同,但是大多都提供了当前活动线程的快 照...
用法使用./gradlew克隆并构建存储库,或者使用co.paralleluniverse:extended-stacktrace:0.1.0-SNAPSHOT快照存储库( https://oss.sonatype.org/content/repositories/snapshots )中的Maven工件co.paralleluniverse...
JVM异常分析文件
jvm源码
jvm 配置jvm参数 配置jvm参数
美团JVM问题定位和排错
jvm从入门到入魔,笔记非常详细,笔记pdf有55页,图文皆备。
jvm源码,jvm-native的源码,jvm支行机制,可对jvm的运行过程进行分析 个人网站:https://www.zhangjunbk.com
jvm
学习关于JVM基础,java内模型的全面透析,Jar hell问题以及解决办法,Class文件格式 • Java编译执行流程 • ClassFile的格式介绍 • ClassFile中FieldInfo和MethodInfo介绍 • 类型描述Descriptor介绍 • ClassFile...
详细描述JVM【50Page】 1:JVM内存模型:类加载机制【转载、验证、准备、解析、初始化】+类装载器【装载器分类、加载原则】+运行时数据区【方法区、堆、虚拟机栈、本地方法栈、程序计数器】。 2:垃圾回收:垃圾确定...
程序运行要用到的内存大于虚拟机能提供的最大内存就发生内存溢出了, 内存溢出的问题要看业务和系统大小而定,对于某些系统可能内存溢出不常见,但某些系统还是很常见的解决的方法
JVM配置资料JVM配置资料JVM配置资料JVM配置资料
JVM问题定位的典型案例分析
深入解析jvm深入解析jvm深入解析jvm深入解析jvm深入解析jvm深入解析jvm
JVM Thread Stack线程栈分析
jvm优化及问题定位 架构师培训 讲解-----------------------------------------------------------------------------------
JVM图解-JVM指令-JVM原型图.rar