java 中Integer包装类的的128陷阱

本文深入探讨Java中Integer类型在-128至127范围内如何利用缓存提高效率,避免重复创建对象,以及这背后的内存分配原理。通过对比int与Integer的实例化过程,阐明了包装类Integer在特定数值区间内指向常量池的机制。

128陷阱

java开发者认为
每次都要开辟新空间会占用大量的资源,因此他们规定在-128~127(因为Java设计者认为大家对数的使用大多在100以内)之间的Integer类型的变量,直接指向常量池中的缓存地址不会new开辟出新的空间常量池存在于方法区,类加载时就有了。

Integer n=1000;
Integer n1=1000;
int m=1000;
int m1=1000;
Integer i=100;
Integer i1=100;
Integer j=new Integer(100);
Integer j1=new Integer(100);
System.out.println(n==n1);
System.out.println(m==m1);
System.out.println(i==i1);
System.out.println(j==j1);

运行结果:
在这里插入图片描述
第一个的话,Integer不等的也很正常,因为Intege是包装类,虽然数值一样,但对象不同,比较栈中对象地址。
第二个好理解,int基础类型,相等
第三个,咋相等了,不是包转类型吗,这就是规定在-128~127(之间的Integer类型的变量,直接指向常量池中的缓存地址,不会new开辟出新的空间。 栈中两个对象引用都是指向同一个常量。
第四个这是创建了对象,会在堆中有一份对象地址,也就是栈中地址指向堆中对象。

评论 4
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值