java包装类型装箱拆箱踩坑
2019-04-17 本文已影响0人
郑捡书
Long l1 = 128L;
Long l2 = 128L;
System.out.println(l1 == l2); //1
System.out.println(l1 == 128); //2
1. Long 包装类型常量 cache 为 -128 到 127 之间(维护在一个常量池中),超过这个范围会重新new一个,所以 l1 和 l2 变量是两个对象。如果都换为127结果为true
2. 一个包装类型和一个非包装类型,则包装类型自动拆箱,这时候相当于两个基本类型long比较内容
3. 两个Double或者两个Float封装类型的相比较一定为false,因为在指定范围内浮点型数据个数是不确定的,每次都是new一个新的出来。(Double是没有缓存范围的)
4. 对于两边都是包装类型的比较 == 比较的是引用,equals 比较的是值,对于两边有一边是表达式(包含算数运算)则 == 比较的是数值(自动触发拆箱过程),对于包装类型 equals 方法不会进行类型转换。
// 坑爹的题目 坑爹的题目 坑爹的题目
Integer i = 1;
Integer i2 = 2;
Long l2 = 2L;
Long l3 = 3L;
// 右边是表达式,发生了拆箱(知识点4);这时候一边是基本类型,一边是封装类型,则包装类型发生拆箱(知识点2)。所以最后其实是两个基本类型的比较。
System.out.println(l3 == i + i2);
System.out.println(i == l3); // 编译不通过,两个是不同的类型
System.out.println(l3 == (i + i2)); // ture
System.out.println(l3 .equals(i + i2)); // false
System.out.println(l3 .equals(i + l2)); // true
java 语句 Integer i = 1; i += 1; 做了哪些事情?
答:首先 Integer i = 1; 做了自动装箱(使用 valueOf() 方法将 int 装箱为 Integer 类型),接着 i += 1; (拆分为i = i + 1; 封装类型和基本类型相加,发生拆箱) 先将 Integer 类型的 i 自动拆箱成 int(使用 intValue() 方法将 Integer 拆箱为 int),完成加法运行之后的 i 再装箱成 Integer 类型。