目录

为什么Java中“1000==1000”为false,而”100==100“为true

Java中“1000==1000”为false,而”100==100“为true的原因:比较两个值为 100 的 Integer 对象时,两个对象的值都在整数缓存的范围内,会指向缓存中的同一个对象,结果为 true。比较两个值为 1000 的 Integer 对象时,值超出了整数缓存的范围,Java 不会使用缓存中的对象,结果为 false。

一、Java中“1000==1000”为false,而”100==100“为true的原因

Java 5 引入了自动装箱和自动拆箱功能,这使得基本数据类型和它们对应的包装类可以在需要时自动转换。例如,当将一个 int 类型的值赋给一个 Integer 对象时,编译器会自动执行装箱操作,将基本数据类型转换为其对应的包装类。

为了提高性能,Java 在自动装箱过程中实现了一个名为整数缓存(Integer Cache)的机制。这个机制会缓存一定范围内的整数对象。在 Java 的默认实现中,缓存的范围是 -128 到 127(包括边界值)。因此,当自动装箱一个位于这个范围内的整数时,将返回缓存中的相同整数对象。

在 Java 中,使用 “==” 操作符比较对象时,实际上是比较它们的引用是否相等,而不是它们的内容是否相等。如果想要比较两个对象的内容是否相等,通常需要使用它们的 equals() 方法。

然而,当使用 “==” 操作符比较基本数据类型时,实际上是比较它们的值是否相等。

在这里,我们实际上是比较两个 Integer 对象,而非基本数据类型 int

当我们比较两个值为 100 的 Integer 对象时,由于这两个对象的值都在整数缓存的范围内(-128 到 127),它们会指向缓存中的同一个对象。因此,使用 “==” 操作符比较它们的引用时,结果为 true。

然而,当我们比较两个值为 1000 的 Integer 对象时,由于它们的值超出了整数缓存的范围,Java 不会使用缓存中的对象。因此,这两个 Integer 对象分别在堆内存中的不同位置,使用 “==” 操作符比较它们的引用时,结果为 false。

一站式研发项目管理平台 PingCode

一站式研发项目管理平台 PingCode

支持敏捷\瀑布、知识库、迭代计划&跟踪、需求、缺陷、测试管理,同时满足非研发团队的流程规划、项目管理和在线办公需要。