我们知道java中对象判断相等,用equal,而不能用==,然而,在某些情况下,使用 ==
判断两个 Long
对象时,比较的结果会是相等的。这个现象与 Java 对于包装类的缓存机制有关。
1. 缓存机制:
Java 对于 Long
、Integer
、Short
、Byte
等包装类,提供了一个内部的对象缓存池。为了提高性能,Java 会缓存一些常用的值,以避免重复创建相同值的对象。具体来说,Long
类型会缓存从 -128 到 127 之间的值。这意味着,如果两个 Long
对象的值都在这个范围内,Java 会返回同一个缓存对象,因此 ==
比较时会返回 true
。
示例:
Long a = 127L;
Long b = 127L;
System.out.println(a == b); // true
在上述代码中,a
和 b
的值都是 127,属于缓存范围,所以 a == b
返回 true
。
2. 超过缓存范围:
如果 Long
的值超出了 -128
到 127
的范围,Java 不会使用缓存,而是会创建新的对象。因此,使用 ==
比较时,会因为它们是不同的对象而返回 false
。
示例:
Long a = 128L;
Long b = 128L;
System.out.println(a == b); // false
System.out.println(a.equals(b)); // true
在这段代码中,a
和 b
的值都是 128,但由于这个值不在缓存范围内,Java 会为每个变量创建一个新的 Long
对象,因此 a == b
返回 false
,而 a.equals(b)
正确地返回 true
。
3. 总结:
- 当
Long
的值在-128
到127
之间时,==
比较可能返回true
,因为这些值被缓存。 - 当
Long
的值超出这个范围时,==
比较会返回false
,因为此时对象引用不同。 - 为了避免这种误解,推荐始终使用
equals()
方法来比较包装类的值。
这样可以避免由于缓存机制导致的意外行为。
特别在进行数据库id进行比较时候,由于开始时候id较小,程序结果是ok的,随着数据不但增多,id越来越大,当大于128以后,程序功能就异常了,这个地方还是需要引以为戒的