Weird Java question: Why does 128 == 128 return False, but 127 == 127 returns True?

Weird Java question: Why does 128 == 128 return False, but 127 == 127 returns True?

This is the topic we are going to discuss today because I think it is very interesting.

If you run the following code:

  1. Class A
  2. {
  3. public   static void main(String[] args)
  4. {
  5. Integer a = 128, b = 128;
  6. System. out .println(a == b);
  7. Integer c = 127, d = 127;
  8. System. out .println(c == d);
  9. }
  10. }

You will get the following result:

  1. false  
  2. true  

We know that if two references point to the same object, then == is true; conversely, if the two references do not point to the same object, then == is not true, even if the contents of the two references are the same. Therefore, the result will be false.

This is where it gets really interesting. If you look inside the Integer.java class, you’ll find an inner private class called IntegerCache.java that provides a cache for all integer objects between -128 and 127.

This thing provides an internal cache for small integers, and when declared like this:

  1. Integer c = 127

This is what it looks like inside:

  1. Integer var3 = Integer .valueOf(127);

In fact, after I decompile the A.class file, the code is as follows:

If we look at the valueOf() class function, we can see:

  1. public   static   Integer valueOf( int i) {
  2. if (i >= IntegerCache.low && i <= IntegerCache.high)
  3. return IntegerCache.cache[i + (-IntegerCache.low)];
  4. return new Integer (i);
  5. }

If the value is between -128 and 127, it returns an instance of that cache.

therefore...

  1. Integer c = 127, d = 127;

Both refer to the same object.

That's why the following code evaluates to true:

  1. System.out.println (c == d) ;

Now you might ask, why would there be a cache for all integers between -128 and 127?

This is because the frequency of use of small integers in this range is much greater than that of other integers in daily life, and the fact that the same underlying object is used multiple times can be effectively optimized for memory through this setting. You can use this feature arbitrarily using the reflection API.

Run the following code and you will see the magic.

  1. public   static void main(String[] args) throws NoSuchFieldException, IllegalAccessException {
  2.  
  3. Class cache = Integer .class.getDeclaredClasses()[0];
  4. Field myCache = cache.getDeclaredField( "cache" );
  5. myCache.setAccessible( true );
  6.  
  7. Integer [] newCache = ( Integer []) myCache.get(cache);
  8. newCache[132] = newCache[133];
  9.  
  10. int a = 2;
  11. int b = a + a;
  12. System. out .printf( "%d + %d = %d" , a, a, b); //
  13. }

The print result is:

  1. 2 + 2 = 5

Let's look at the disassembled code again:

Is this the same problem as above?

But why is the result 2 + 2 = 5?

Let's continue to look at the Integer source code to gain a deeper understanding of the Integer cache mechanism. Here is a screenshot:

According to the source code, we can find that the method of modifying the upper limit of the Integer cache has some minor flaws. Let's take a look at what the API suggests to us:

  1. the size   of the cache may be controlled by the {@code -XX:AutoBoxCacheMax=< size >} option .

It turns out that we only need to set -XX:AutoBoxCacheMax=133 at runtime.

<<:  Android performance optimization memory leak

>>:  How to use fastboot to flash the original image to Android

Recommend

Ten hidden tricks of WeChat that most people don’t know

1. Send original image/video It is well known tha...

Analysis of the four major user needs of the financial community!

I have been operating in the financial management...

Sogou advertising, account opening, and display formats

What is Sogou Promotion? Sogou search promotion i...

Starting from Dash iOS open source, don’t pursue perfect code too much

(Screenshot of Dash iOS source code) Some time ag...

5 ways to increase the weight of Tik Tok!

So the question is, how to improve the weight of ...

5 social media trends to watch in 2016

[[161459]] In the past, we could only rely on two...

Why do you have such a hard time finding seed users?

After the product is launched, someone is needed ...

When birds fly south, which “South” are they heading to?

Author: Yunhai Science Popularization The article...

How to optimize image traffic on mobile devices

[[171480]] In addition to script style files, mos...