浅析java中的基本数据类型与包装类型的相关操作和模式
java中的基本类型包括boolean,byte,short,int,long,double,float,char。
基本类型对应的包装类型为 Boolean,Byte,Short,Integer,Long,Double,Float,Character
首先介绍基本数据类型的自动装箱,拆箱。这个是J2SE 5.0开始的功能。
通常创建一个类的对象实例需要通过new关键字,当我们创建基本数据类型的包装类型的对象的时候,可以直接用:
Integer i = 100;
实际上执行这句代码的时候,系统为我们执行了Integer i = Integer.valueOf(100);这就时基本数据类型的自动装箱功能。
基本数据类型的包装类型在参与运算的时候,自动转换为基本数据类型参与运算。这就时基本数据类型的自动拆箱功能。
public class AutoBox {
public static void main(String [] args) {
//定义俩个包装类型
Integer i1 = 100;
Integer i2 = 100;
System.out.println(i1+i2);//自动拆箱
System.out.println(i1.getClass());//自动装箱
}
}
运行结果:
200
class java.lang.Integer
再看一段代码:
public class AutoBox {
public static void main(String [] args) {
Integer iObj = 3;
System.out.println(iObj+12);
//String 不是基本的数据类型
String s1 = new String("abc");
String s2 = new String("abc");
System.out.println(s1 == s2);
Integer i1 = 127;
Integer i2 = 127;
System.out.println(i1 == i2);
Integer i3 = Integer.valueOf(127);
Integer i4 = Integer.valueOf(127);
System.out.println(i3==i4);
Integer i5 = 128;
Integer i6 = 128;
System.out.println(i5 == i6);
}
}
运行结果:
15
false
true
true
false
发现一个问题 为什么 i1 = i2 = 127 的时候,i1和i2相等,i5 = i6 = 128的时候不相等?
在分析结果时,先要了解一部分内在的设定:在自动装箱时,把int变成Integer的时候,是有规则的,当int的值在-128——127之间时,返回的不是一个新new出来的Integer对象,而是一个已经缓存在堆中的Integer对象【可以理解为:系统已经将-128——127之间的Integer缓存到数组中,如果你要把一个int变成一个Integer对象,首先区缓存中找,如果缓存中存在,直接返回引用,如果不存在,则new】
如此便可以分析出来,i1与i2指向的其实是已经缓存在堆中的同一块内存单元。所以其相等。i5和i6在缓存中无法找到,所以各自执行new操作,所以他们的内存地址不同,如果使用i5.equals(i6);则为true。关于java中 <a>equals和==的区别</a> 请参看另一篇博文。
ok,有以上的基础,最后再分析一个问题
Integer n1 = new Integer(47);
Integer n2 = new Integer(47);
System.out.println(n1.equals(n2));
System.out.println(n1 == n2);//??为什么它又是false呢?
输出结果:
true
false
原因其实很简单,这里执行的是new操作,需要再堆中开辟俩个存储空间用来存储n1,n2,所以n1,n2指向的是俩个不同的存储空间,所以为false。