(Java)equals 与 ==的区别

 

在上一篇hashCode与equals区别的文章中,发现,equals 与  ==的区别有:

若一个类没有覆盖equals方法,那么equals与== 意义相同,都是比较的是地址空间

若类在其中覆盖equals方法,

@Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (getClass() != obj.getClass())
            return false;
        Student other = (Student) obj;
        if (age != other.age)
            return false;
        if (name == null) {
            if (other.name != null)
                return false;
        } else if (!name.equals(other.name))
            return false;
        return true;
    }

那么此时equals比较的是对象的内容,与==不同

Java的String类  Date类  File类等包装类都对equals方法进行了重写,也就是说,这些类型进行用equals比较时,比较的是两个值而不是地址的指向

      String str1 = "abc";
      String str2 = "abc";
       System.out.println(str1==str2);//true

对于第一行String str1 = "abc";先在栈中创建一个对 String类的对象引用变量str1,然后通过引用去字符串常量池 里找有没有"abc",如果没有,则将"abc"存放进字符串常量池。这里常量池中并没有“abc”。即在编译期已经创建好(直接用双引号定义的)“abc”,存储在了常量池中。对于第2行String str2 = "abc";创建了对String类的对象引用str2,然后通过引用去字符串常量池 里找有没有"abc",如果没有,则将"abc"存放进字符串常量池 ,并令str2指向”abc”,如果已经有”abc” 则直接令str2指向“abc”。这里我们在第三行代码中已经将“abc”这个字符串存储进了常量池。所以str2和str1指向的是同一个“abc”,返回true。

注:

1:两个通过new生成的Integer变量永远是不相等的(因为new生成的是两个对象,其内存地址不同)。

Integer i = new Integer(100);
Integer j = new Integer(100);
System.out.print(i == j); //false

2:包装类Integer和基本数据类型int比较时,java会自动拆包装为int,然后进行比较,实际上就变为两个int变量的比较 

Integer i = new Integer(100);
int j = 100;
System.out.print(i == j); //true

3:非new生成的Integer变量指向的是java常量池中的对象,而new Integer()生成的变量指向堆中新建的对象,两者在内存中的地址不同

Integer i = new Integer(100);
Integer j = 100;
System.out.print(i == j); //false

 

4:对于两个非new的Integer对象,如果变量的值在区间-128到127之间,结果为true,如果两个变量的值不在此区间,则比较结果为false

Integer i = 10;
Integer j = 10;
System.out.print(i == j); //true
Integer i = 200;
Integer j = 200;
System.out.print(i == j); //false

java在编译Integer i = 10 ;时,会理解为Integer i = Integer.valueOf(10);,而java API中对Integer类型的valueOf的定义如下:

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

java对于-128到127之间的数,会进行缓存,Integer i = 127时,会将127进行缓存,下次再写Integer j = 127时,就会直接从缓存中取,否则,常量缓冲池中没有127时就会new一个新的值,存入到常量池中

参考博文:

https://www.cnblogs.com/whcwkw1314/p/8044947.html

https://www.cnblogs.com/guodongdidi/p/6953217.html