自动装箱 与 拆箱

前言:Byte、Short、Integer、Long这几个类的valueOf方法实现类似的。所以在[-128,127]区间内,==比较的时候,值总是相等的(指向的是同一对象),在这个区间外是不等的。 

原因:上述四个包装类回先创建[-128,127]区间内的对象放入堆中。如果发生基本类型自动装箱的范围在此区间内,则返回已创建对象的引用。

注:装箱过程是通过调用包装器的valueOf方法实现的
拆箱过程是通过调用包装器的xxxValue方法实现的(xxx表示对应的基本数据类型) 

例如:

Integer a = 110;

Integer b = 110;

System.out.println(a==b);//返回true

Integer c = new Integer(110);//使用new一定创建一个新的对象。a和c指向的不是用以对象

Integer 与 int类型之间的比较情况如下:

  1. int和int之间,用==比较,肯定为true。基本数据类型没有equals方法 
  2. int和Integer比较,Integer会自动拆箱,== 和 equals都肯定为true 
  3. int和new Integer比较,Integer会自动拆箱,调用intValue方法, 所以 == 和 equals都肯定为true 
  4. Integer和Integer比较的时候,由于直接赋值的话会进行自动的装箱。所以当值在[-128,127]中的时候,由于值缓存在IntegerCache中,那么当赋值在这个区间的时候,不会创建新的Integer对象,而是直接从缓存中获取已经创建好的Integer对象。而当大于这个区间的时候,会直接new Integer。 当Integer和Integer进行==比较的时候,在[-128,127]区间的时候,为true。不在这个区间,则为false
    当Integer和Integer进行equals比较的时候,由于Integer的equals方法进行了重写,比较的是内容,所以为true 
  5. Integer和new Integer : new Integer会创建对象,存储在堆中。而Integer在[-128,127]中,从缓存中取,否则会new Integer.
    所以 Integer和new Integer 进行==比较的话,肯定为false ; Integer和new Integer 进行equals比较的话,肯定为true 
  6. new Integer和new Integer进行==比较的时候,肯定为false ; 进行equals比较的时候,肯定为true
    原因是new的时候,会在堆中创建对象,分配的地址不同,==比较的是内存地址,所以肯定不同 
上一篇:2021-09-16


下一篇:equals与==运用和区别(深入源码理解)