深入剖析128陷阱&自动拆装箱

导读:本篇文章讲解 深入剖析128陷阱&自动拆装箱,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

一、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

深入剖析128陷阱&自动拆装箱

在上面的示例中我们用Integer定义的数其实是简写形式,正确的写法:(自动装箱)

Integer e = Integer.valueOf(128);
Integer f = Integer.valueOf(128);

第一个返回false

第二个返回true

二、当Ingeter与int比较时为true,因为拆箱总比装箱性能好(装箱要构建新的对象浪费空间)integer默认做了自动拆箱的处理

深入剖析128陷阱&自动拆装箱

第一个返回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对象

深入剖析128陷阱&自动拆装箱

 规定了cache数组的范围

深入剖析128陷阱&自动拆装箱

 所以当我们用==比较两个用Integer定义值为128的数时,会返回false,此时n1和n2是封装在两个对象中,比较应用.equals()方法

        Integer n1 = 128;
        Integer n2 = 128;
        System.out.println(n1.equals(n2));

返回true

这就是所谓的128陷阱 

三、8种基本数据类型对应的包装类

深入剖析128陷阱&自动拆装箱

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/80132.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!