【Java】IntegerCache的妙用和陷阱

412 篇文章 483 订阅 ¥19.90 ¥99.00
这篇博客探讨了Java中Integer对象的缓存机制,特别是IntegerCache如何在-128到127之间提高性能并节省内存。作者通过示例展示了为何在这个范围内Integer对象的`==`比较会返回相同结果,并提醒开发者这可能导致预期外的行为。此外,文章还提到其他类似缓存机制存在于Long, Short, Byte, Character类中。" 132633561,19694618,C#实现客户端开机自启动,"['C#开发', 'Windows应用', '注册表编程']
摘要由CSDN通过智能技术生成

在这里插入图片描述

1.概述

转载:https://mp.weixin.qq.com/s/PnVkrMzYeOiepPKjl4MKVA

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

public class Test {



    public static void main(String[] args) {

        Integer n1 = 123;

        Integer n2 = 123;



        Integer n3 = 128;

        Integer n4 = 128;



        System.out.println(n1 == n2);

        System.out.println(n3 == n4);

    }



}

答案如下,请选择刮开:

true
false

是否和你预想的一致?

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

2. 原理

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

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

我们来翻看下jdk中Integer的源码
在这里插入图片描述

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

在这里插入图片描述

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

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

扩展

这种缓存行为不仅用于Integer类,而且还用于Long,Short,Byte,Character,大家可以去这些类里面查看XxxCache的类和valueOf方法源码,原理大致相同,但它们的边界略有一二,也不能进行最大边界的配置。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值