一、128陷阱指的是两个Integer对象直接用==判定在某个范围内返回为true
- 两个Integer对象直接用==判定 在某个范围内(-128~127)返回为true;
引用类型用==判定 就是判定的两个对象是不是地址一样
如果传入value数值在-127~128范围内,那么所有在这个范围内被创建的对象实际 都指向同一个地址,即被预创建Integer对象所在的地址
- 两个Integer对象直接用==判定 在范围外返回为false;
如果传入value数值不在范围内,那么每次被创建的对象都指向一个新的且不同的地址,即通过new关键字由JVM分配的新地址。
- 一个int和一个Integer对象用==判定返回true
Integer是int的封装类,当int和Integer进行==比较的时候,Integer会自动拆装为int类型,所以返回true
在(-128,127)范围内为true
在上面的示例中我们用Integer定义的数其实是简写形式,正确的写法:(自动装箱)
Integer e = Integer.valueOf(128);
Integer f = Integer.valueOf(128);
第一个返回false
第二个返回true
二、当Ingeter与int比较时为true,因为拆箱总比装箱性能好(装箱要构建新的对象浪费空间)integer默认做了自动拆箱的处理
第一个返回true
第二个返回true
Integer就是int的包装类,自动装箱就是将基本数据类型转换为包装类;自动拆箱就是将包装类转换成基本数据类型
Integer d = 10;//自动装箱 Integer b = Integer.valueOf(10);
int e = d; //自动拆箱 int e = d.intValue
源码角度分析:
128陷阱出现的原因就是Integer的valueOf方法中有一个存储[-128-127]的catch数组,这个数组就相当于一个缓存,当我们定义的数在-128-127之间时,就直接返回该内存中的地址
在自动装箱的方法中,由源码可知先判断了i是否存在于IntegerCache中的cache数组中,如若存在则直接返回数组中的值,若不存在则构建一个新的Integer对象
规定了cache数组的范围
所以当我们用==比较两个用Integer定义值为128的数时,会返回false,此时n1和n2是封装在两个对象中,比较应用.equals()方法
Integer n1 = 128;
Integer n2 = 128;
System.out.println(n1.equals(n2));
返回true
这就是所谓的128陷阱
三、8种基本数据类型对应的包装类
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/80132.html