您好,登錄后才能下訂單哦!
本篇內容介紹了“java中為什么int==Integer為true”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
先看現象吧
執行下面的代碼及輸出結果:
int a = 1;Integer b = 1;Integer c = new Integer(1);System.out.println(a==b);//trueSystem.out.println(a==c);//trueSystem.out.println(b==c);//false
通常大家對此的解釋是,==對于基本類型來說比較的是值,對于引用類型來說比較的是引用,即指向的對象的內存地址。這樣解釋沒錯,b==c結果為false毋庸置疑,因為兩個都是引用類型。但是為什么a==b(a==c)一個是基本類型一個是引用類型,比較的時候還是值比較呢?
這個時候我們不妨把.java源文件編譯后的.class文件使用反編譯工具反編譯成源碼,看看虛擬機內部是如何處理a==b的。
.class文件使用jd-gui反編譯后的:
int a = 1;Integer b = Integer.valueOf(1);Integer c = new Integer(1);System.out.println(a == b.intValue());System.out.println(a == c.intValue());System.out.println(b == c);
看到這想必大家都明白了吧,其實基本類型a和引用類型b比較時,引用類型b調用自身的intValue()方法獲取Integer實際表示的int類型的值,即a == b.intValue()還是兩個int類型的變量進行值比較。符合上述:==對于基本類型來說比較的是值,對于引用類型來說比較的是引用,即指向的對象的內存地址。
說到這,還要解釋下為什么兩個引用類型的值一樣而引用不一樣以及基本變量為什么是值比較。
其實基本變量int a在內存里只有一份,保存在棧(保存基本類型的變量數據及引用類型的引用)中,Integer b和Integer c中的int值都指向棧中同一個int,不會重新在棧中創建相同的int值。
而對于Integer b和Integer c,其實例是保存在堆(保存所有new出來的對象)中,雖然表示的int值相同,但是在堆中有兩份,每次new都會在堆中開辟一片空間保存new的內容,故Integer b和Integer c分別在兩片不同的內存空間存儲,所以指向的內存地址不同。
而對于Integer b = 1;其反編譯后為Integer b = Integer.valueOf(1); 而valueOf()方法內部是調用了new。
JDK中Integer.valueOf()源碼:
public static Integer valueOf(int i) { if (i >= IntegerCache.low && i <= IntegerCache.high) return IntegerCache.cache[i + (-IntegerCache.low)]; return new Integer(i);}
“java中為什么int==Integer為true”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。