1. Java中包装类和原生类型
class="java">
8个原生类型分别是:byte, short, int, long, float, double, char, boolean。
8个包装类分别是:Byte, Short, Integer, Long, Float, Double, Character, Boolean。
原生数据类型与包装类型的双向转换
自动转型总原则:byte,short,char(同级)-> int -> long -> float -> double (由低精度到高精度)
public class IntegerTest{
public static void main(String[] args){
int a = 10;
Integer integer = new Integer(a);
int b = integer.intValue();
System.out.println(a == b);
}
}
运行结果:
true
2. Java中自动装箱和拆箱
装箱就是自动将基本数据类型转换为包装器类型 Integer i = 10;
拆箱就是自动将包装器类型转换为基本数据类型 int n = i;
装箱过程是通过调用包装器的valueOf方法实现的
拆箱过程是通过调用包装器的 xxxValue方法实现的(xxx代表对应的基本数据类型)
Integer类有一个缓存,它会缓存介于-128~127之间的整数。Integer.valueof()方法会将缓存值返回,不会生成新的对象。
在装箱时,valueOf方法会被自动调用:如果整型字面值在[-128,127]之间,便返回 IntegerCache.cache(在类加载时就自动创建)中已经存在的对象的引用;否则,创建一个新的Integer对象并返回。
public class BoxTest {
public static void main(String[] args){
Integer i1 = 100;
Integer i2 = 100;
if(i1 == i2){
System.out.println("i1 == i2");
}else{
System.out.println("i1 != i2");
}
}
}
运行结果:i1 == i2
public class BoxTest {
public static void main(String[] args){
Integer i1 = 200;
Integer i2 = 200;
if(i1 == i2){
System.out.println("i1 == i2");
}else{
System.out.println("i1 != i2");
}
}
}
运行结果:i1 != i2
Double就没有这种情况,是因为在某个范围内的整型数值的个数是有限的,而浮点数却不是。
Integer、Short、Byte、Character、Long 这几个类的valueOf方法的实现是类似的,有限可列举,共享[-128,127];
Double、Float的valueOf方法的实现是类似的,无限不可列举,不共享;
Boolean的valueOf方法的实现不同于以上的整型和浮点型,只有两个值,有限可列举,共享;
Integer i = new Integer(xxx); 不会触发自动装箱;
Integer i = xxx; 会触发自动装箱;执行效率和资源占用在一般性情况下([-128,127])要高
详细参考博客: https://blog.csdn.net/justloveyou_/article/details/52651211