JIT实时编译优化带来的问题:几千次异常以后取不到错误信息了

Posted 快乐崇拜234

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JIT实时编译优化带来的问题:几千次异常以后取不到错误信息了相关的知识,希望对你有一定的参考价值。

正文在下面,先打个广告:

问题

public static void main(String[] args) 
    BigDecimal value1 = new BigDecimal("0.0000");
    BigDecimal value2 = new BigDecimal("0.0000");
    int i = 0;
    while (i < 11000) 
        try 
            value1.subtract(value2).divide(value2, 6, BigDecimal.ROUND_HALF_UP);
         catch (Exception e) 
            if (e.getMessage() == null) 
                //为什么执行5000此左右,e.msg 为空了呢?
                System.out.println(i + "=======================");
            
        
        i++;
    

上面这段代码,运行,刚开始e.getMessage()是可以取到数据的。然后运行到5000此左右,就会开始打印=====了。

是不是很诡异!

看ArithmeticException 的源码,也没有什么特殊的,RuntimeException也找不到相关逻辑。因此怀疑是JIT运行时编译优化造成的;跟公司大牛沟通后确认了这个结论。
所以在业务代码逻辑编写的时候,不要采用e.getMessage()的值来做校验逻辑。

public class ArithmeticException extends RuntimeException 
    private static final long serialVersionUID = 2256477558314496007L;
    public ArithmeticException() 
        super();
    
    public ArithmeticException(String s) 
        super(s);
    


以上是关于JIT实时编译优化带来的问题:几千次异常以后取不到错误信息了的主要内容,如果未能解决你的问题,请参考以下文章

CLR 语言优化。语言编译器 VS JIT 编译器

尝试在 MonoTouch.CoreGraphics.CGContext.DrawPDFPage 中 JIT 编译方法异常

PHP 8.0重大版本更新正式发布:支持JIT编译器,性能提升高达3倍

JIT

Xamarin IOS LexDB Save - 尝试 JIT 编译的异常(包装器委托调用)

看了这篇JIT编译器,你也能说你会java性能优化了!