java_异常没有堆栈信息(没有堆栈信息的异常)_java.lang.NullPointerException

 

原因:

发现服务器的异常,但没有打印堆栈信息。

[2016-xx-xx 13:04:51] 

java.lang.NullPointerException

查看代码,确实是获取了堆栈信息的。

正好别人也遇到这个问题。感谢作者~~

 

资料 http://blog.csdn.net/bxyz1203/article/details/7713133

昨天财务出现一个问题,线上一直在报错:日志截屏如下:

有异常,但是就只有一个java.lang.NullPointerException异常,这个没有堆栈信息,我怎么查问题呢?后来经过查询,这个问题其实是跟JDK5引入的一个新特性有关,对于一些频繁抛出的异常,JDK为了性能会做一个优化,在JIT重新编译后会抛出没有堆栈的异常。在使用server模式的时候,这个优化是开启的,我们的服务器跑在server模式下并且jdk版本是6,因此在频繁抛出java.lang.NullPointerException异常一定次数后优化开始起作用,只抛出没有堆栈的异常信息了。参考文档:http://java.sun.com/j2se/1.5.0/relnotes.html#hotspot

扫描二维码关注公众号,回复: 568804 查看本文章
为了验证,我还简单写了一段代码验证下:
[java]  view plain  copy
 
  1. public class TestLog {  
  2.     public static void main(String[] args) {  
  3.         int i = 1;  
  4.         while (i <= 200000) {  
  5.             try {  
  6.                 Long l = null;  
  7.                 l.toString();  
  8.             } catch (Exception e) {  
  9.                 if (e.getStackTrace().length == 0) {  
  10.                     System.out.println("count is" + i);  
  11.                     break;  
  12.                 }  
  13.             }  
  14.             i++;  
  15.         }  
  16.     }  
  17. }  
运行结果:
[fin@vm-crm-dev-144-100 longer]$ java TestLog
count is20708
为了能看到堆栈,可以重启服务器再观察,也可以看下以前老的日志。

但是大部分情况下,我们建议还是去掉此优化:通过启动参数中加入:
-XX:-OmitStackTraceInFastThrow

 

 

0

5

4

3

3

3

2

1

 

猜你喜欢

转载自fantaxy025025.iteye.com/blog/2330098