zoukankan      html  css  js  c++  java
  • 【Java学习】Integer、new Integer() 和 int 比较和相关的面试题

    一、基本概念区分

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

    二、 Integernew Integer() 和 int 的三者比较

    2.1、两个 new Integer() 比较 ,永远是 false。

    因为new生成的是两个对象,其内存地址不同,故永不相等。

    Integer i = new Integer(100);
    Integer j = new Integer(100);
    System.out.print(i == j);  //false
    
    • 1
    • 2
    • 3

    2.2、两个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
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    分析:
    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);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

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

    2.3、Integer 和 new Integer() 比较 ,永远为 false。

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

    Integer i = new Integer(100);
    Integer j = 100;
    System.out.print(i == j);  //false
    
    • 1
    • 2
    • 3

    2.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
    • 2
    • 3

    三、面试题

    示例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
    	}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    答案是

    i == i2 = true
    i == i3 = true
    i4 == i5 = true
    i6 == i7 = false
    i5 == i8 = false
    i9 == i10 = false
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    示例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 不解释
    	}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29

    示例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);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    解析:
    i01 == i02 。 i01.intValue()==i02 两个值的比较59==59 -->true;

    i01 == i03 。 由于 59在-128到127之间,所以,i01和i03的赋值操作返回的是同一个对象。都是从Cache中返回的同一个对象,对象地址相同 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);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    答案:

    true
    false
    false
    true
    作者:gtea 博客地址:https://www.cnblogs.com/gtea
  • 相关阅读:
    814. Binary Tree Pruning
    50. Pow(x, n)
    698. Partition to K Equal Sum Subsets
    416. Partition Equal Subset Sum
    150. Evaluate Reverse Polish Notation
    322. Coin Change
    Vulnerable Kerbals CodeForces
    D. Domino for Young
    C. Long Beautiful Integer
    B. Modulo Equality
  • 原文地址:https://www.cnblogs.com/gtea/p/13620406.html
Copyright © 2011-2022 走看看