• IntegerCache的妙用和陷阱


    转载自 IntegerCache的妙用和陷阱

    考虑下面的小程序,你认为会输出为什么结果?

    1. public class Test {
    2.     public static void main(String[] args) {
    3.         Integer n1 = 123;
    4.         Integer n2 = 123;
    5.         Integer n3 = 128;
    6.         Integer n4 = 128;
    7.         System.out.println(n1 == n2);
    8.         System.out.println(n3 == n4);
    9.     }
    10. }

    答案如下,请选择刮开:

    true

    fase

    是否和你预想的一致?

    我们知道==比较的是对象的引用,那这里为什么会这出这种情况呢?

    原理

    首先这是JDK在1.5版本中添加的一项新特性,把-128~127的数字缓存起来了,用于提升性能和节省内存。所以这个范围内的自动装箱(相当于调用valueOf(int i)方法)的数字都会从缓存中获取,返回同一个数字,所以现在你理解为什么了吧。同时这也会给我们开发带来预想不到的陷阱,直得注意!!

    而我们通过new Integer(1)这样就不会从缓存中获取,大家可以自行测试。

    我们来翻看下jdk中Integer的源码

    上面是IntegerCache的源码,把从-128~high放在缓存中

    上面是valueOf的源码,先从缓存中获取,获取不到再new一个返回

    从源码里面我们可以看到最小边界是-128,最大边界可以通过-XX:AutoBoxCacheMax进行配置,但也不会大于Integer.MAX_VALUE最大值。

  • 相关阅读:
    shell中的 echo命令
    shell中的运算符
    shell中的替换
    shell中的元字符
    springcloud-sleuth的使用
    springcloud-sleuth之zipkun运行和概念介绍
    springcloud-sleuth是什么
    消息总线(bus)和消息驱动(stream)的区别
    springcloud-stream之持久化
    springcloud-stream之消费者重复消费
  • 原文地址:https://www.cnblogs.com/minghaiJ/p/10740014.html
Copyright © 2020-2023  润新知