Java 128陷阱

Java 128陷阱

1、背景

当我们在比较Java中Interger类型的数据时,有时候会发现两个明明相同的值,最后比较的结果为false,这是为什么呢?这就要了解一下我们常说的“128陷阱”
在Java中,Interger是数据类型int的封装类,Java设计者是这么认为的:

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

下面我们来看代码:

public class Test {

    public static void main(String[] args) {

        Integer a=2;
        Integer b=2;
        System.out.println(a==b);

        Integer c=200;
        Integer d=200;
        System.out.println(c==d);
    }
}

输出结果:

在这里插入图片描述

2、原因分析

而我们在声明:

Integer a=2;
//编译时,该语句会自动装箱为
Integer a=Integer.valueOf(2);

从而调用valueOf()的方法,现在我们来看一下这个方法的原码:
在这里插入图片描述

high和slow的值:

在这里插入图片描述

valueOf()方法中有一个(Integer数组)cach数组

  • 如果在: -128–127 这个空间就会调用元空间里面的数值,返回的是整个cach数组,只要值相同,两个numb1和numb2地址就相等
  • 当不在这个空间内,则这个方法会new一个新的空间,此时两个numb1和numb2的方法在堆中,此时两个数的内存地址不相等,如果用==进行比较时,因内存地址不同则输出true
  • 如果用equals方法进行比较时,内容相同,则都会返回true

3、结论

Integer值在-128到127之间用==比较时,返回true,否则返回false

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值