java 拆箱 类型不对_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 类型。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值