一、背景
今天在群里看到有人提出这样一个问题:Java中输出1000 == 1000输出为false,而100 ==100为true?
作为一个半吊子Java初学者,当场有点震惊。居然还有这回事?
二、求证
为此,我捡起来久久未用的Java,找了个编译器进行测试
class Untitled {
public static void main(String[] args) {
System.out.println("江南蜡笔小新");
System.out.println("https://blog.csdn.net/ftimes");
Integer a = 1000, b = 1000;
System.out.println(a == b);//1
Integer c = 100, d = 100;
System.out.println(c == d);//2
}
}
输出为:
当真如群友所说。
三、答案
在网上查了之后才知道,这个问题已经有许多人提过了,我截取一部分靠谱的观点供参考:
基本知识:我们知道,
如果两个引用指向同一个对象,用== 表示它们是相等的。
如果两个引用指向不同的对象,用 == 表示它们是不相等的,即使它们的内容相同。
而Integer.java 类中有一个内部私有类——IntegerCache.java,它缓存了从-128到127之间的所有的整数对象。
所以,Integer c = 100, d = 100; //指向了同一个对象
因此,返回了ture。
现在你可能会问,为什么这里需要缓存?
合乎逻辑的理由是,在此范围内的“小”整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。
然而,通过反射API你会误用此功能。
ps:
后来我考虑到Python的机制,想着python不会有这种坑吧?
偷偷地试了一下,并不会出现这种情况,这应该是Java自带的一个特性。