这是jdk1.5以后才引入的新的内容
我们知道int是基本类型,Integer是int的包装类是引用类型的
一、自动装箱
我们定义一个int类型的变量很简单:
int num = 10;
而原则上定义一个引用类型的数要new一个对象出来:
Integer num = new Integer(10);
自动装箱就是:
Integer num = 10;
10就是一个基本的类型却可以直接赋值给Integer,但jdk1.5后你就可以进行这样的声明,这就是自动装箱
二、自动拆箱
//装箱
Integer num = 10;
//拆箱
int num1 = num;
自动拆箱还有一个经典的用法:我们知道引用类型的变量的值就是一个地址值,并不是实际的值,所以引用类型一般不能直接用来进行加减乘除运算的
但是自动拆箱却可以:
Integer num = 10;
System.out.println(num--);
这就是自动拆箱的最直观体现,拆成了int类型从而参加运算
再举一个例子:
//在-128~127 之外的数
Integer num1 = 200; Integer num2 = 200;
System.out.println("num1==num2: "+(num1==num2));
// 在-128~127 之内的数
Integer num3 = 100; Integer num4 = 100;
System.out.println("num3==num4: "+(num3==num4));
输出结果:num1==num2: false num3==num4: true
为什么会这样?这就归结于java对于Integer与int的自动装箱与拆箱的设计,是一种模式:叫享元模式(flyweight)
为了加大对简单数字的重利用,java定义:在自动装箱时对于值从–128到127之间的值,它们被装箱为Integer对象后,会存在内存中被重用,始终只存在一个对象
而如果超过了从–128到127之间的值,被装箱后的Integer对象并不会被重用,即相当于每次装箱时都新建一个 Integer对象;明白了吧
以上的现象是由于使用了自动装箱所引起的,如果你没有使用自动装箱,而是跟一般类一样,用new来进行实例化,就会每次new就都一个新的对象;
这里我就理解为了Integer中有一个-128-127的常量池,取这个范围内的数字时候对象保存的地址值都在这个常量池内所以相等,而这个范围之内就每次都new一个对象了
这个的自动装箱拆箱不仅在基本数据类型中有应用,在String类中也有应用,比如我们经常声明一个String对象时:
String str = "abc";
//代替下面的声明方式
String str = new String("abc");