(Integer) 128 == (Integer) 128 为false详细解读
所學知識
這里涉及到的知識點為Java的自動裝箱、拆箱問題
先看簡單示例:
第一組輸出為true,第二組false,第三組false。第二組false很正常因為Integer對象地址不同,但為什么第一組與第三組結果不同,不是應該一樣的嗎?
Integer a = 127;Integer b = 127;System.out.println(a == b);Integer c = new Integer(128);Integer d = new Integer(128);System.out.println(c == d);Integer e = 128;Integer f = 128;System.out.println(e == f);知識探索:
要弄明白這個問題,首先要熟練掌握Java自動裝箱、拆箱相關的知識,Java中的自動裝/拆箱發生在運算操作和比較操作時,例如:
Integer a = 10;a = a + 2;System.out.println(a > 10);a = a + 2; 先把a拆箱為int類型,再進行a + 2運算,再把結果裝箱為Integer類型。
當使用==來比較時有三種情況:
Integer a = 10;Integer b = 10;Integer c = new Integer(12);Integer d = new Integer(12);System.out.println(a == 10);System.out.println(a == b);System.out.println(c == d);
1、 a == 10 左右兩邊一邊int類型一邊Integer類型,a先拆箱再比較。
2、 a == b 與 c == d都是對地址進行比較,不同的是a、b都指向同一對象,Integer a,b=10;中的10存放在常量區,a,b 都指向它。c, d中的new Integer()在堆中產生兩個不同對象,地址不同因此返回false。
為什么(Integer)127 == (Integer)127 和 (Integer)128 == (Integer)128的值不同:
Integer類部分源碼如下:
private static class IntegerCache {static final int low = -128;static final int high;static final Integer[] cache;private IntegerCache() {}static {int var0 = 127;String var1 = VM.getSavedProperty("java.lang.Integer.IntegerCache.high");int var2;if (var1 != null) {try {var2 = Integer.parseInt(var1);var2 = Math.max(var2, 127);var0 = Math.min(var2, 2147483518);} catch (NumberFormatException var4) {}}high = var0;cache = new Integer[high - -128 + 1];var2 = -128;for(int var3 = 0; var3 < cache.length; ++var3) {cache[var3] = new Integer(var2++);}assert high >= 127;}}大概意思就是:Integer類 -128~127 之間的值都是直接從緩存中取出的,(Integer)127 == (Integer)127兩邊裝箱后,實際指向堆內存中同一個對象,大于127 后就new一個新的對象返回。(Integer)128 == (Integer)128,裝箱為引用類型后,沒有做緩存,指向堆內存中不同對象,所以比較結果為false。至于為什么要緩存,若不緩存,每次都要new一個新對象,資源消耗多,所以緩存一些常用的數,來減少資源損耗。
參考:https://blog.csdn.net/Rongbo_J/article/details/68947525
總結
以上是生活随笔為你收集整理的(Integer) 128 == (Integer) 128 为false详细解读的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 求只有2,3,5组成的第n小个数字
- 下一篇: 为什么要用动态代理?静态代理与动态代理详