查看原文
其他

傻傻分不清?Integer、new Integer() 和 int 的面试题

chenxiangxiang Java技术栈 2020-10-08


这篇有意思:IntegerCache的妙用和陷阱!

基本概念的区分:

1、Integer 是 int 的包装类,int 则是 java 的一种基本数据类型 2、Integer 变量必须实例化后才能使用,而int变量不需要 3、Integer 实际是对象的引用,当new一个 Integer时,实际上是生成一个指针指向此对象;而 int 则是直接存储数据值 4、Integer的默认值是null,int的默认值是0

Integer、new Integer() 和 int 的比较

1、两个 new Integer() 变量比较 ,永远是 false 因为new生成的是两个对象,其内存地址不同

  1. Integer i = newInteger(100);

  2. Integer j = newInteger(100);

  3. System.out.print(i == j); //false

2、Integer变量 和 new Integer() 变量比较 ,永远为 false。因为 Integer变量 指向的是 java 常量池 中的对象, 而 new Integer() 的变量指向 堆中 新建的对象,两者在内存中的地址不同。

  1. Integer i = newInteger(100);

  2. Integer j = 100;

  3. System.out.print(i == j); //false

3、两个Integer 变量比较,如果两个变量的值在区间-128到127 之间,则比较结果为true,如果两个变量的值不在此区间,则比较结果为 false 。

  1. Integer i = 100;

  2. Integer j = 100;

  3. System.out.print(i == j); //true


  4. Integer i = 128;

  5. Integer j = 128;

  6. System.out.print(i == j); //false

分析:Integer i = 100 在编译时,会翻译成为 Integer i = Integer.valueOf(100),而 java 对 Integer类型的 valueOf 的定义如下:

  1. publicstaticInteger valueOf(int i){

  2. assertIntegerCache.high >= 127;

  3. if (i >= IntegerCache.low && i <= IntegerCache.high){

  4. returnIntegerCache.cache[i + (-IntegerCache.low)];

  5. }

  6. returnnewInteger(i);

  7. }

java对于-128到127之间的数,会进行缓存。所以 Integer i = 127 时,会将127进行缓存,下次再写Integer j = 127时,就会直接从缓存中取,就不会new了。

4、 int 变量 与 Integer、 new Integer() 比较时,只要两个的值是相等,则为true 因为包装类Integer 和 基本数据类型int 比较时,java会自动拆包装为int ,然后进行比较,实际上就变为两个int变量的比较。

  1. Integer i = newInteger(100); //自动拆箱为 int i=100; 此时,相当于两个int的比较

  2. int j = 100;

  3. System.out.print(i == j); //true

示例1:

  1. publicclassIntegerDemo {

  2. publicstaticvoid main(String[] args) {

  3. int i = 128;

  4. Integer i2 = 128;

  5. Integer i3 = newInteger(128);


  6. System.out.println("i == i2 = " + (i == i2)); // Integer会自动拆箱为int,所以为true

  7. System.out.println("i == i3 = " + (i == i3)); // true,理由同上


  8. Integer i4 = 127;// 编译时被翻译成:Integer i4 = Integer.valueOf(127);

  9. Integer i5 = 127;

  10. System.out.println("i4 == i5 = " + (i4 == i5));// true


  11. Integer i6 = 128;

  12. Integer i7 = 128;

  13. System.out.println("i6 == i7 = " + (i6 == i7));// false


  14. Integer i8 = newInteger(127);

  15. System.out.println("i5 == i8 = " + (i5 == i8)); // false


  16. Integer i9 = newInteger(128);

  17. Integer i10 = newInteger(128);

  18. System.out.println("i9 == i10 = " + (i9 == i10)); // false

  19. }

  20. }

答案是

  1. i == i2 = true

  2. i == i3 = true

  3. i4 == i5 = true

  4. i6 == i7 = false

  5. i5 == i8 = false

  6. i9 == i10 = false

示例2:

  1. package demo1.demo1;


  2. publicclassCampare {


  3. publicstaticvoid main(String[] args) {


  4. Integer a = newInteger(127), b = newInteger(128);


  5. int c = 127, d = 128, dd = 128;

  6. Integer e = 127, ee = 127, f = 128, ff = 128;


  7. System.out.println(a == b); // false 因为a,b都是new出来的对象,地址不同所以为false

  8. System.out.println(a == c); // true a会自动拆箱为int类型

  9. System.out.println(a == e); // false 指向的地址不同a是new出来的


  10. System.out.println(e == c); // true e会自动拆箱为int类型

  11. System.out.println(e == ee);// true Integer对 处于-128到127范围之间,指向了同一片地址区域


  12. System.out.println(b == f); // false 指向的地址不同b是new出来的

  13. System.out.println(f == d); // true f自动拆箱为int类型


  14. System.out.println(f == ff); /*

  15. * false 指向的不是同一片地址区域。

  16. * 在Integer类型中,-128到127存放的是同一片区域地址,

  17. * 之外的数是另外开辟空间来进行 存储的

  18. */

  19. System.out.println(d == dd); // true 不解释

  20. }

  21. }

示例3:

  1. Integer i01 = 59;

  2. int i02 = 59;

  3. Integer i03 =Integer.valueOf(59);

  4. Integer i04 = newInteger(59);

以下输出结果为false的是:

  1. System.out.println(i01== i02);

  2. System.out.println(i01== i03);

  3. System.out.println(i03== i04);

  4. 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。

  1. Integer i01 = 128;

  2. int i02 = 128;

  3. Integer i03 = Integer.valueOf(128);

  4. Integer i04 = newInteger(128);

以下输出结果为false的是:

  1. System.out.println(i01 == i02);

  2. System.out.println(i01 == i03);

  3. System.out.println(i03 == i04);

  4. System.out.println(i02 == i04);

答案:

  1. true

  2. false

  3. false

  4. true


作者:chenxiangxiang

来源:cnblogs.com/cxxjohnson/p/10504840.html

- END -
推荐阅读:
1、代码写成这样,老夫无可奈何!

2、厉害了,淘宝千万并发,14 次架构演进…

3、面试官问线程安全的List,看完再也不怕了

4、JDK 13 的 12 个新特性,真心涨姿势了

5、分享一份 2019 最新 Java 架构师学习资料

关注Java技术栈公众号在后台回复:Java,可获取一份栈长整理的最新Java 技术干货。

点击「阅读原文」和栈长学更多~

    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存