Java基础篇:== 和 equals的区别

==:

  • 基本数据类型比较:基本数据类型之间采用==进行比较,比较的是基本类型的值

  • 引用数据类型比较:引用数据类型进行比较的时候,是比较内存中的地址

    如果int类型与它的包装类型Integer进行比较,是会自动拆箱,然后比较数值

public static void main(String[] args) {
        Integer i1 = 1000;
        Integer i2 = 1000;
        System.out.println(i1 == i2);
}

那么这段代码的运行结果是怎样的呢?

false

答案是false,如果使用数值直接给Integer类型赋值,就相当于完成了一次自动装箱的机制(JDK1.5之后引入自动拆装箱机制),so Integer i1 = 1000;等同于 Integer i1 = Integer.valueOf(1000);,下面我们看一眼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);
}

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() {}
    }

在valueOf中引入了一个Integer缓存池,如果数值在-128到127之间直接从缓存池中取出该数值,如果不在则重新new Integer()并返回。所以上面的i1 和 i2的比较数值不在缓存池的范围 结果为false

equals:

在第一次了解==和equals的概念的时候,一直以为=比较的是地址,equals比较的是内容

public boolean equals(Object obj) {
        return (this == obj);
}

看完Object类里面的equals方法之后,这明明也是比较的地址。那么为什么String、Integer等类,创建不同的对象值却一样equals返回的结果为true,请看如下源码(String类)

public boolean equals(Object anObject) {
	 if (this == anObject) {  //如果内存地址相同,返回true
	        return true;
	    }
	    if (anObject instanceof String) {  //判断参数是否为string类型
	        String anotherString = (String)anObject;
	        int n = value.length;
	        if (n == anotherString.value.length) {  //判断参数长度是否相同
	            char v1[] = value;
	            char v2[] = anotherString.value;
	            int i = 0;
	            while (n-- != 0) {
	                if (v1[i] != v2[i])
	                    return false;
	                i++;
	            }
	            return true;
	        }
	    }
	    return false;
	}	

public int hashCode() {
        int h = hash;
        if (h == 0 && value.length > 0) {
            char val[] = value;

            for (int i = 0; i < value.length; i++) {
                h = 31 * h + val[i];
            }
            hash = h;
        }
        return h;
    }

通过String类的源码可以很清晰的看到String类重写了equals和hashCode方法,然后进行的是内容的比较。

所以默认情况下equals比较的是内存地址,我们可以通过重写equals和hashCode方法对自己想比较的内容进行比较。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值