自动装箱与拆箱及其陷阱
自动装箱(Autoboxing):
在jdk 1.5之前,如果你想要定义一个value为100的Integer对象,则需要这样做:Integer aa = new Integer (100);
而在jdk 1.5中,自动装箱首次被引入。例如 Integer aa = 100; aa为一个Integer类型的引用,100为Java中的基础数据类型(int)。而这种直接将一个基础数据类型传给其相应的封装类的做法,便是自动装箱。
再看下源码里Integer类的valueOf(int i)方法的具体实现,说明装箱就是jdk自动帮我们完成了调用Integer.valueOf(100)的操作:
1 public static Integer valueOf(int i) { 2 if(i >= -128 && i <= IntegerCache.high) 3 return IntegerCache.cache[i + 128]; 4 else 5 return new Integer(i); 6 }
自动拆箱(Unboxing):
1 Integer integer100 = 100; 2 int int100 = integer100;
从上面的代码中,大家可看出integer100为一个Integer类型的引用,int100为一个int类型的原始数据类型。但是,我们可以将一个Integer类型的对象赋值给其相应原始数据类型的变量,这便是拆箱。
拆箱与装箱是相反的操作。装箱是将一个原始数据类型赋值给相应封装类的变量。而拆箱则是将一个封装类的变量赋值给相应原始数据类型的变量。
再看下源码里Integer类的intValue()方法的具体实现,说明拆箱就是jdk自动帮我们完成了intValue()方法的调用,针对以上的例子而言,便是调用integer100变量的的intValue()方法,将其返回值赋给了int100:
1 public int intValue() { 2 return value; 3 }
陷阱1:
1 Integer integer400 = 400; 2 int int400 = 400; 3 System.out.println(integer400 == int400);// 输出:true
原理:==运算是判断两个对象的地址是否相等或者判断两个基础数据类型的值是否相等,因此,
如果输出true:说明对比的是两个基础类型的值,即integer400拆箱了;
如果输出false:说明对比的是两个对象的地址是否相等,那此时地址必然不相等,即int400装箱了。