Integer、new Integer() 和 int 比較的面試題


基本概念的區分:

1、Integer 是 int 的包裝類,int 則是 java 的一種基本數據類型
2、Integer 變量必須實例化后才能使用,而int變量不需要
3、Integer 實際是對象的引用,當new一個 Integer時,實際上是生成一個指針指向此對象;而 int 則是直接存儲數據值
4、Integer的默認值是null,int的默認值是0

Integernew Integer() 和 int 的比較

  • 1、兩個 new Integer() 變量比較 ,永遠是 false

因為new生成的是兩個對象,其內存地址不同

Integer i = new Integer(100); Integer j = new Integer(100); System.out.print(i == j); //false
  • 2、Integer變量 和 new Integer() 變量比較 ,永遠為 false。

因為 Integer變量 指向的是 java 常量池 中的對象,
而 new Integer() 的變量指向 堆中 新建的對象,兩者在內存中的地址不同。

Integer i = new Integer(100); Integer j = 100; System.out.print(i == j); //false
  • 3、兩個Integer 變量比較,如果兩個變量的值在區間-128到127 之間,則比較結果為true,如果兩個變量的值不在此區間,則比較結果為 false 。
Integer i = 100; Integer j = 100; System.out.print(i == j); //true Integer i = 128; Integer j = 128; System.out.print(i == j); //false

分析:
Integer i = 100 在編譯時,會翻譯成為 Integer i = Integer.valueOf(100),而 java 對 Integer類型的 valueOf 的定義如下:

public static Integer valueOf(int i){ assert IntegerCache.high >= 127; if (i >= IntegerCache.low && i <= IntegerCache.high){ return IntegerCache.cache[i + (-IntegerCache.low)]; } return new Integer(i); }

java對於-128到127之間的數,會進行緩存。
所以 Integer i = 127 時,會將127進行緩存,下次再寫Integer j = 127時,就會直接從緩存中取,就不會new了。

  • 4、 int 變量 與 Integer、 new Integer() 比較時,只要兩個的值是相等,則為true

因為包裝類Integer 和 基本數據類型int 比較時,java會自動拆包裝為int ,然后進行比較,實際上就變為兩個int變量的比較。

Integer i = new Integer(100); //自動拆箱為 int i=100; 此時,相當於兩個int的比較 int j = 100; System.out.print(i == j); //true

示例1:

public class IntegerDemo { public static void main(String[] args) { int i = 128; Integer i2 = 128; Integer i3 = new Integer(128); System.out.println("i == i2 = " + (i == i2)); // Integer會自動拆箱為int,所以為true System.out.println("i == i3 = " + (i == i3)); // true,理由同上 Integer i4 = 127;// 編譯時被翻譯成:Integer i4 = Integer.valueOf(127); Integer i5 = 127; System.out.println("i4 == i5 = " + (i4 == i5));// true Integer i6 = 128; Integer i7 = 128; System.out.println("i6 == i7 = " + (i6 == i7));// false Integer i8 = new Integer(127); System.out.println("i5 == i8 = " + (i5 == i8)); // false Integer i9 = new Integer(128); Integer i10 = new Integer(128); System.out.println("i9 == i10 = " + (i9 == i10)); // false } }

答案是

i == i2 = true
i == i3 = true
i4 == i5 = true
i6 == i7 = false
i5 == i8 = false
i9 == i10 = false

示例2:

package demo1.demo1; public class Campare { public static void main(String[] args) { Integer a = new Integer(127), b = new Integer(128); int c = 127, d = 128, dd = 128; Integer e = 127, ee = 127, f = 128, ff = 128; System.out.println(a == b); // false 因為a,b都是new出來的對象,地址不同所以為false System.out.println(a == c); // true a會自動拆箱為int類型 System.out.println(a == e); // false 指向的地址不同a是new出來的 System.out.println(e == c); // true e會自動拆箱為int類型 System.out.println(e == ee);// true Integer對 處於-128到127范圍之間,指向了同一片地址區域 System.out.println(b == f); // false 指向的地址不同b是new出來的 System.out.println(f == d); // true f自動拆箱為int類型 System.out.println(f == ff); /* * false 指向的不是同一片地址區域。 * 在Integer類型中,-128到127存放的是同一片區域地址, * 之外的數是另外開辟空間來進行 存儲的 */ System.out.println(d == dd); // true 不解釋 } } 

 

示例3:

Integer i01 = 59; int i02 = 59; Integer i03 =Integer.valueOf(59); Integer i04 = new Integer(59); 以下輸出結果為false的是: System.out.println(i01== i02); System.out.println(i01== i03); System.out.println(i03== i04); System.out.println(i02== i04);

解析:
i01 == i02 。 i01.intValue()i02 兩個值的比較5959 -->true;

i01 == i03 。 由於 59在-128到127之間,所以,i01和i03的賦值操作返回的是同一個對象。都是從chche中返回的同一個對象,對象地址相同 true;

i03 == i04。 i03是來自緩存值,i04是新new的對象 ,二者不是同一個對象,所以false。

i02 == i04。 和第一個類似,true。

答案是 C 。

示例4:
與示例3的唯一不同,就是將值全部改成128。

Integer i01 = 128; int i02 = 128; Integer i03 = Integer.valueOf(128); Integer i04 = new Integer(128); 以下輸出結果為false的是: System.out.println(i01 == i02); System.out.println(i01 == i03); System.out.println(i03 == i04); System.out.println(i02 == i04);
 

答案:

true
false
false
true


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM