9
Integer integer1 = 127;
Integer integer2 = 127;
System.out.println(integer1 == integer2);//true

integer1 = 128;
integer2 = 128;
System.out.println(integer1 == integer2);//false

I found it returns == (if it is) under the range of -128 - 127 , why is there such specification ?

jmj
  • 237,923
  • 42
  • 401
  • 438

2 Answers2

28

Because of this code in Integer.valueOf(int):

public static Integer valueOf(int i) {
    if(i >= -128 && i <= IntegerCache.high)
        return IntegerCache.cache[i + 128];
    else
        return new Integer(i);
}

Explanation:

Integer integer1 = 127 is a shortcut for Integer integer1 = Integer.valueOf(127), and for values between -128 and 127 (inclusive), the Integers are put in a cache and returned multiple times, while higher and lower numbers generate new Integers each time.

Sean Patrick Floyd
  • 292,901
  • 67
  • 465
  • 588
  • 2
    Add to that, JDK specs say Integers between -128 and 128 are cached. Depending on your JDK, additional values may also be cached. – Reverend Gonzo Apr 07 '11 at 13:35
  • Ok. what is the significance of this, isn't it a easter egg, won't it lead to some bad thing>? – jmj Apr 07 '11 at 13:37
  • 3
    @Jigar No, it's documented behavior. Problems only result if you compare objects with ==. Use == for primitives and equals() for Objects. Integer is an Object, not a primitive. – Sean Patrick Floyd Apr 07 '11 at 13:44
3

== will return true if it's the exact same object. Boxing integers in Java 'intern' numbers within that that range, so any boxed version of such a number will result in the exact same object.

To get avoid this effect in comparisons, use .equals()

System.out.println(integer1.equals(integer2));
Jim Blackler
  • 22,946
  • 12
  • 85
  • 101
  • Ok. what is the significance of this, isn't it a easter egg, won't it lead to some bad thing>? – jmj Apr 07 '11 at 13:41
  • 2
    If you use .equals() to compare the content of a variable and == to compare the actual object references no bad things will happen, trust me. – Jim Blackler Apr 07 '11 at 13:44