Java 中Long,Integer,Short, Byte等包装类型为什么使用==可以判断相等

我们知道java中对象判断相等,用equal,而不能用==,然而,在某些情况下,使用 == 判断两个 Long 对象时,比较的结果会是相等的。这个现象与 Java 对于包装类的缓存机制有关。

1. 缓存机制:

Java 对于 LongIntegerShortByte 等包装类,提供了一个内部的对象缓存池。为了提高性能,Java 会缓存一些常用的值,以避免重复创建相同值的对象。具体来说,Long 类型会缓存从 -128 到 127 之间的值。这意味着,如果两个 Long 对象的值都在这个范围内,Java 会返回同一个缓存对象,因此 == 比较时会返回 true

示例:

Long a = 127L;
Long b = 127L;

System.out.println(a == b); // true

在上述代码中,ab 的值都是 127,属于缓存范围,所以 a == b 返回 true

2. 超过缓存范围:

如果 Long 的值超出了 -128127 的范围,Java 不会使用缓存,而是会创建新的对象。因此,使用 == 比较时,会因为它们是不同的对象而返回 false

示例:

Long a = 128L;
Long b = 128L;

System.out.println(a == b); // false
System.out.println(a.equals(b)); // true

在这段代码中,ab 的值都是 128,但由于这个值不在缓存范围内,Java 会为每个变量创建一个新的 Long 对象,因此 a == b 返回 false,而 a.equals(b) 正确地返回 true

3. 总结:

  • Long 的值在 -128127 之间时,== 比较可能返回 true,因为这些值被缓存。
  • Long 的值超出这个范围时,== 比较会返回 false,因为此时对象引用不同。
  • 为了避免这种误解,推荐始终使用 equals() 方法来比较包装类的值。

这样可以避免由于缓存机制导致的意外行为。

特别在进行数据库id进行比较时候,由于开始时候id较小,程序结果是ok的,随着数据不但增多,id越来越大,当大于128以后,程序功能就异常了,这个地方还是需要引以为戒的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值