聊聊Java中的拆箱和装箱操作

本文深入探讨Java中Integer对象的缓存机制及其对比较运算的影响。通过具体代码示例,解析不同情况下Integer对象的比较结果,揭示了-128至127范围内整数的共享缓存原理。

在刷谷歌面试题的过程中,发现一道有意思的题目,以前没有特别注意,忽略了一些东西,特此记录。

题目要求输出以下代码的结果:

public class MyTest {
    public static void main(String[] args) {
        System.out.println(new Integer(2) == 2);
        System.out.println(new Integer(2) == new Integer(2));
        System.out.println(Integer.valueOf(2) == Integer.valueOf(2));
        System.out.println(Integer.valueOf(1000) == Integer.valueOf(1000));
        System.out.println(Integer.valueOf(2).intValue() == 2);
        System.out.println(new Integer(2).equals(new Integer(2)));
    }
}

结果分析:

new Integer(2) == 2,输出为true,因为Java自己拆箱了,即执行了new Integer(2).intValue()。

new Integer(2) == new Integer(2),输出为false,因为产生了两个装箱,==比较的是地址,而非值,所以为false。

Integer.valueOf(2) == Integer.valueOf(2),输出为true。

Integer.valueOf(1000) == Integer.valueOf(1000),输出为false。

以上两个着重讲一下,我们不妨看一下Java关于valueOf的源码:

而代码中的low和high如下:

由此我们知道,Integer有一个缓存,在-128到127范围内,会共用同一个数字,否则新创建一个,因此一个true,一个false。

Integer.valueOf(2).intValue() == 2,输出为true,因为拆箱了。

new Integer(2).equals(new Integer(2)),输出为true,因为equals比较的是数值,下面是equals源码。

 

转载于:https://www.cnblogs.com/DarrenChan/p/10311355.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值