Home > Java > javaTutorial > Java Integer Comparison: Why Does `==` Sometimes Fail, and When Should I Use `.equals()`?

Java Integer Comparison: Why Does `==` Sometimes Fail, and When Should I Use `.equals()`?

Barbara Streisand
Release: 2024-12-30 06:29:08
Original
371 people have browsed it

Java Integer Comparison: Why Does `==` Sometimes Fail, and When Should I Use `.equals()`?

Java: Integer Equality Conundrum - equals vs. ==

While integers and their corresponding wrapper class, Integer, can often be used interchangeably, a peculiar behavior has been encountered when comparing two Integer values using the equality operator (==).

Unexpected Result

Consider the following code snippet:

Integer cdiCt = ...;
Integer cdsCt = ...;
...
if (cdiCt != null && cdsCt != null && cdiCt != cdsCt)
    mismatch = true;
Copy after login

Surprisingly, this conditional appeared to incorrectly set mismatch to true even when the underlying values of cdiCt and cdsCt were equal (e.g., both containing the value 137).

Autoboxing Issue

The culprit behind this puzzling behavior lies in Java's autoboxing mechanism. When comparing primitives (e.g., int) with their corresponding wrapper classes (e.g., Integer), autoboxing automatically converts the primitive to its wrapper object. However, this conversion introduces a subtle complication.

JVM Caching

For performance reasons, the JVM caches Integer values between -128 and 127. When creating an Integer object within this range, the JVM simply returns the cached instance instead of creating a new one. This caching mechanism ensures that all references to the same primitive value (within the cached range) point to the same Integer instance.

== Comparison Failure

When comparing two Integer objects using the equality operator (==), Java checks if they refer to the same object in memory. If they do, the comparison returns true; otherwise, it returns false. However, when comparing two Integer objects that are both within the cached range and hold the same primitive value, they will reference the same cached instance, leading to a false positive in the == comparison.

Solution: Use equals Method

To avoid this issue, it is recommended to use the equals method when comparing Integer objects. The equals method performs a value-based comparison, ensuring that two Integer objects are considered equal only if they have the same primitive value.

if (cdiCt != null && cdsCt != null && !cdiCt.equals(cdsCt))
    mismatch = true;
Copy after login

Conclusion

While using == to compare Integer objects within the cached range (-128 to 127) may appear to work, it can lead to unexpected results. To ensure reliable equality comparisons, always utilize the equals method instead.

The above is the detailed content of Java Integer Comparison: Why Does `==` Sometimes Fail, and When Should I Use `.equals()`?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template