八大基本数据类型对应的包装类
byte ----> Byte
char ----> Character
short ----> Short
int ----> Integer
long ----> Long
float ----> Float
double ----> Doble
包装类—>基本数据类型
拆箱(unboxing)
以int为例:
Integer integer = 1;
//自动拆箱(auto-boxing)
int num1 = integer;
//手动拆箱
int num2 = integer.intValue();
基本数据类型—>包装类
装箱(boxing)
int num = 1;
//自动装箱(aoto-boxing)
Integer integer1 = num;
//手动装箱
Integer integer2 = Integer.valueOf(num);
String–>int
String str = "23";
//方式一:(推荐)
int num1 = Integer.parseInt(str);
//方式二:
Integer integer = Integer.valueOf(str);
int num2 = integer.intValue();
int–>String
int num = 23;
//方式一(推荐)
Integer integer1 = Integer.valueOf(num);
String str1 = Integer.toString(integer1);
//方式二(不推荐)
Integer integer2 = Integer.valueOf(num);
String str2 = integer2.toString();
//方式三(强烈推荐)
String str3 = num + "";
包装类中的缓存设计:
为了考虑到性能,就把常用的值先声明好放到缓存区中,这样就不用每次都要创建新的对象
Byte、Short、Integer、Long:缓存的范围大小[-128,127]
Character:缓存的范围大小[0,127]
例如:
Integer i1 = new Integer(10);//古老的构造器,被淘汰了
Integer i2 = new Integer(10);
i1 == i2 ?-->flase
Integer i3 = 120;
Integer i4 = Integer.valueOf(120);
i3 == i4 ?--->true
Integer i5 = 200;
Integer i6 = Integer.valueOf(200);
i5 == i6 ?--->false
结论:
超出了范围所以会重新new Integer();那么它们指向的就是不同一个对象
没有超出范围指向同一个范围,说明 i3、i5底层调用跟i4、i6调用是一样
为什么会淘汰掉new Integer()?因为它没有设计缓存区