您好,登錄后才能下訂單哦!
Java的整型類型中如何實現2+2=5,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
先看下這段神奇的Java代碼:
public static void main(String[] args) throws Exception { doSomethingMagic(); System.out.printf("2 + 2 = %d", 2 + 2); }
執行結果:2 + 2 = 5
那么doSomethingMagic到底做了什么神奇的事情呢?先看代碼:
private static void doSomethingMagic() throws Exception { Class cache = Integer.class.getDeclaredClasses()[0]; Field c = cache.getDeclaredField("cache"); c.setAccessible(true); Integer[] array = (Integer[]) c.get(cache); array[132] = array[133]; }
所以這個例子其實包含了Java中整型類型Integer的一個知識點。
可能有的朋友對于doSomethingMagic里面的代碼有點摸不著頭腦,讓我們先查看上圖第17行 2 + 2反編譯出來的代碼:
編輯器將2+ 2的值先計算出來,等于4。最后System.out.println打印出來的值,實際上是Integer.valueOf(4)的返回值。
那么我們就查看JDK里Integer.valueOf的實現:
上面的實現代碼,從830行到832行,邏輯非常清楚:如果valueOf的參數i在IntegerCache.low和IntegerCache.high之間,即[-128, 127]的閉區間,則直接從IntegerCache這個緩存區域里返回。只有當輸入參數i不在[-128,127]區間內,才執行代碼832,基于輸入參數i創建一個新的Integer實例。
帶著這個理念,我們再看doSomethingMagic就清楚多了。這個方法通過Java反射將上圖IntegerCache的成員cache設置成可訪問:setAccessible(true), 然后將IntegerCache的第132個元素的值用第133個元素的值覆蓋。
我們從Eclipse調試器里發現,Integer cache里第132個元素的值為4,第133個元素的值為5。本來Integer.valueOf方法,對于輸入4,從Integer cache里返回第132個元素的值,即4。現在這個元素的值被第133個元素即5覆蓋了,所以最后得到了 2 + 2 = 5。
用一句話概括這個場景: 2 + 2 = 4 = Integer.valueOf(4) = 5 ( 因為4在Integer cache里對應的記錄已經被我們的代碼顯式替換成了5)。
看完上述內容,你們掌握Java的整型類型中如何實現2+2=5的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。