Java的equal方法和==的一个坑

equal方法和==的区别

如果是基本数据类型,用==比较的是其值,如果是复合数据类型,用==比较的是它们在内存中的存放地址,因此除非是同一个new出来的对象,否则比较结果都是false。此时想比较复合数据类型的值,应该用equal方法。

实例

两个Interger 数据做比较

Integer a=1;
Integer b=1;
Integer c=128;
Integer d=128;

System.out.println (a == b);
System.out.println (c == d);
System.out.println (a.equals ( b ));
System.out.println (c.equals ( d ));

运行结果

true
false
true
true

为什么会出现这种情况?

原因解析

用IDEA软件打开其对应的.class文件,这个文件是.java文件被编译成字节码之后,被反编译之后出来经过编译器(javac)自动装箱之后的具体代码

        Integer a = Integer.valueOf(1);
        Integer b = Integer.valueOf(1);
        Integer c = Integer.valueOf(128);
        Integer d = Integer.valueOf(128);
        System.out.println(a == b);
        System.out.println(c == d);
        System.out.println(a.equals(b));
        System.out.println(c.equals(d));

首先,用equal比较a和b,c和d的值,输出为true,这一点无可争议,那么为何a==b的结果是true,而c==d的结果却是false呢?这就要从Interger的valueOf()方法说起

public static Integer valueOf(int var0) {
        return var0 >= -128 && var0 <= Integer.IntegerCache.high?Integer.IntegerCache.cache[var0 + 128]:new Integer(var0);
    }

//其中IntegerCache.high为assert high >= 127;

从上面valueOf的源码可以看出,对于-128~127之间的值,valueOf()方法直接返回一个在Integer缓存数组中的Integer,对于超过这个范围的值,此方法会new出来一个新的Integer用来返回。

这就解释了为什么a==b为true,而c==d为false了,前文提到过,==代表着比较在内存中的存放地址,a和b的值在-128~127之间,因此都指向Integer的内存数组中的同一处,因此结果相等,c和d的值不在此范围内,因此指向了两个不同的对象,其内存地址不同,结果为false。

参考:Integer判断相等,到底该用==还是equals

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值