Java是面向對象的編程語言,一切都是對象,但是為了編程的方便還是引入了基本數據類型,為了能夠將這些基本數據類型當成對象操作,Java為每一個基本數據類型都引入了對應的包裝類型(wrapper class),int的包裝類就是Integer,從Java 5開始引入了自動裝箱/拆箱機制,使得二者可以相互轉換,對應如下:
原始類型:boolean,char,byte,short,int,long,float,double
包裝類型:Boolean,Character,Byte,Short,Integer,Long,Float,Double
順便一提,Java中的基本數據類型只有以上8個,除了基本類型(primitive type),剩下的都是引用類型(reference type)。
所以最基本的一點區別是:Ingeter是int的包裝類,int的初值為0,Ingeter的初值為null。除此之外還有區別,請看代碼:
public class TestInteger { public static void main(String[] args) { int i = 128; Integer i2 = 128; Integer i3 = new Integer(128); System.out.println(i == i2); //Integer會自動拆箱為int,所以為true System.out.println(i == i3); //true,理由同上 Integer i4 = 127;//編譯時被翻譯成:Integer i4 = Integer.valueOf(127); Integer i5 = 127; System.out.println(i4 == i5);//true Integer i6 = 128; Integer i7 = 128; System.out.println(i6 == i7);//false Integer i8 = new Integer(127); System.out.println(i5 == i8); //false Integer i9 = new Integer(128); Integer i10 = new Integer(123); System.out.println(i9 == i10); //false } }
為什么i4和i5比是true,而i6和i7比是false呢?關鍵就是看valueOf()函數了,這個函數對於-128到127之間的數,會進行緩存, Integer i5 = 127時,會將127進行緩存,下次再寫Integer i6 = 127時,就會直接從緩存中取,就不會new了。所以i4和i5比是true,而i6和i7比是false。
而對於后邊的i5和i8,以及i9和i10,因為對象不一樣,所以為false。
以上的情況總結如下:
1,無論如何,Integer與new Integer不會相等。不會經歷拆箱過程,new出來的對象存放在堆,而非new的Integer常量則在常量池(在方法區),他們的內存地址不一樣,所以為false。
2,兩個都是非new出來的Integer,如果數在-128到127之間,則是true,否則為false。因為java在編譯Integer i2 = 128的時候,被翻譯成:Integer i2 = Integer.valueOf(128);而valueOf()函數會對-128到127之間的數進行緩存。
3,兩個都是new出來的,都為false。還是內存地址不一樣。
4,int和Integer(無論new否)比,都為true,因為會把Integer自動拆箱為int再去比。