Integer比较时用==还是equals

目录

一、==

二、修改integer的缓存范围

三、使用equals


一、==

        一般情况在代码代码中比较interger的值时用==是没有问题的,但是也存在一定的范围。

         可以看到,当Integer表示的值在[-128 ~ 127]之间,使用==时能达到我们的预期的。

        

 可是一旦超过这个范围,结果就不是我们想要的了。

 如上图,我们看到一旦integer超过了[-128~127],==比较的结果为false;

这是因为Integer在进行比较的时候会自动的进行拆箱操作,而进行拆箱操作的时候会调用valueOf方法。

        源码:

    public static Integer valueOf(int i) {
        if (i >= IntegerCache.low && i <= IntegerCache.high)
            return IntegerCache.cache[i + (-IntegerCache.low)];
        return new Integer(i);
    }

 而IntegerCache.low ~ IntegerCache.high是从IntegerCache中获取的,IntegerCache缓存范围是[-128~127],一旦超出这个范围就得不到预期的结果。

        源码如下:

private static class IntegerCache {
        static final int low = -128;
        static final int high;
        static final Integer cache[];

        static {
            // high value may be configured by property
            int h = 127;
            String integerCacheHighPropValue =
                sun.misc.VM.getSavedProperty("java.lang.Integer.IntegerCache.high");
            if (integerCacheHighPropValue != null) {
                try {
                    int i = parseInt(integerCacheHighPropValue);
                    i = Math.max(i, 127);
                    // Maximum array size is Integer.MAX_VALUE
                    h = Math.min(i, Integer.MAX_VALUE - (-low) -1);
                } catch( NumberFormatException nfe) {
                    // If the property cannot be parsed into an int, ignore it.
                }
            }
            high = h;

            cache = new Integer[(high - low) + 1];
            int j = low;
            for(int k = 0; k < cache.length; k++)
                cache[k] = new Integer(j++);

            // range [-128, 127] must be interned (JLS7 5.1.7)
            assert IntegerCache.high >= 127;
        }

        private IntegerCache() {}
    }

二、修改integer的缓存范围

当然这个缓存范围是可以修改的,如下图操作:

-XX:AutoBoxCacheMax=200

 测试:

        修改自动拆箱的缓存最大值为200时,得到验证。

        

三、使用equals

        

         分析:

        equals方法底层调用了intValue()方法。

    public boolean equals(Object obj) {
        if (obj instanceof Integer) {
            return value == ((Integer)obj).intValue();
        }
        return false;
    }

         结论:在使用Integer比较数值相等时,建议使用equals。


                
  • 9
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 在Java中,'=='和'equals()'方法都可以用于比较两个对象是否相等,但是它们之间有一些区别。 当比较两个基本数据类型时,例如'int',使用'=='是可以的,因为它们的值可以直接比较。然而,当比较两个对象时,'=='比较的是对象的引用是否相等,即它们是否指向相同的内存地址。而'equals()'方法比较的是对象的内容是否相等,即它们在逻辑上是否相等。 对于'Integer'类,'=='只有在比较两个相同的'Integer'对象时才会返回true。这是因为对于小的整数值,Java会将其缓存起来并重用同一个对象,但对于大的整数值则不会缓存。因此,如果比较两个大的整数值,'=='可能会返回false。而使用'equals()'方法则可以比较两个'Integer'对象的值是否相等。 综上所述,如果要比较两个'Integer'对象的值是否相等,应该使用'equals()'方法。 ### 回答2: 在Java语言中,integer比较应该使用equals方法,而不是==操作符。因为Integer是一个类,它将int数据类型装箱为一个包装类对象,此时使用==操作符比较的是Integer对象的引用地址,而不是它们存储的值。因此,如果您使用==操作符比较两个Integer对象,您将得到与您想要的结果不同的结果。 例如,下面这个例子比较了两个Integer对象: Integer a = new Integer(10); Integer b = new Integer(10); if (a == b) { System.out.println("a == b"); } else { System.out.println("a != b"); } 运行结果将是a != b,即使a和b都存储值10,因为它们是两个不同的对象。 相反,equals方法比较的是两个对象存储的值,而不是它们的引用地址。因此,正确的比较两个Integer对象的方法是使用equals方法,如下所示: Integer a = new Integer(10); Integer b = new Integer(10); if (a.equals(b)) { System.out.println("a equals b"); } else { System.out.println("a not equals b"); } 现在将输出a equals b,因为equals方法比较的是这两个对象存储的值,它们都是10。 ### 回答3: 在Java语言中,integer类型是一个对象,可以用“==”和equals方法进行比较。 使用“==”进行比较比较的是引用地址,即判断两个Integer对象是否指向同一个内存地址。如果两个Integer对象指向同一个地址,返回true,否则返回false。 而使用equals方法进行比较,则是比较两个Integer对象的值是否相等。如果相等,返回true,否则返回false。这是因为Integer类重写了Object类的equals方法,使其比较对象的值。 因此,如果需要比较Integer对象的值是否相等,应该使用equals方法。如果需要比较两个引用是否指向同一个对象,应该使用“==”进行比较。 需要注意的是,当使用“==”比较两个小于等于127的整数时,不一定会返回false,这是因为Java中对于小于等于127的整数,会有一个缓存池,将这些整数的对象缓存下来以便重复使用,所以使用“==”比较这些整数时,可能会返回true。但这并不代表使用“==”比较Integer对象就是正确的做法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

科特er

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值