java包装类型装箱拆箱踩坑

  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 类型。

你可能感兴趣的:(java包装类型装箱拆箱踩坑)