【java基础】 == 和 equals() 的区别

==号和equals()方法都是比较是否相等的方法,那它们有什么区别和联系呢? java

首先,==号在比较基本数据类型(指的值类型)时比较的是值,而用==号比较两个对象时比较的是两个对象的地址值ide

int x = 10;
int y = 10;
String str1 = new String("abc");
String str2 = new String("abc");
System.out.println(x == y); // 输出true
System.out.println(str1 == str2); // 输出false

那equals()方法呢?咱们能够经过查看源码知道,equals()方法存在于Object类中,由于Object类是全部类的直接或间接父类,也就是说全部的类中的equals()方法都继承自Object类,而经过源码咱们发现,Object类中equals()方法底层依赖的是==号,那么,在全部没有重写equals()方法的类中,调用equals()方法其实和使用==号的效果同样,也是比较的地址值,然而,Java提供的全部类中,绝大多数类都重写了equals()方法,重写后的equals()方法通常都是比较两个对象的值:this

public class Test {
    public static void main(String[] args) {
        Student s1 = new Student(23);
        Student s2 = new Student(23);
        System.out.println(s1.equals(s2));
    }
}

class Student{
    private int age;
    public Student(){}

    public Student(int age){
        this.age = age;
    }
}

这里自定义了一个Student类,没有重写equals()方法,最后的输出结果是:falsespa

class Student{
    private int age;
    public Student(){}

    public Student(int age){
        this.age = age;
    }

    @Override
    public boolean equals(Object obj){
        if (obj instanceof Student) {
            Student stu = (Student) obj;
            return this.hashCode() == stu.hashCode();
        }
        return false;
    }

    @Override
    public int hashCode(){
        return this.age;
    }
}

在重写了equals()方法后,输出结果变成了true。对象

如今一些基本的已经讲的差很少了,接下来咱们回到第一个例子:blog

String str1 = new String("abc");
String str2 = new String("abc");
System.out.println(str1.equals(str2));
System.out.println(str1 == str2);

根据上面所讲,第一个是true,第二个是false,确实如此,那继续看下面的例子:继承

String s1 = "abc";
String s2 = "abc";
System.out.println(s1.equals(s2));
System.out.println(s1 == s2);

此次的结果和上一个的是同样的吗?答案是:true true 
为何第二个会是true呢? 
这就涉及到了内存中的常量池,常量池属于方法区的一部分,当运行到s1建立对象时,若是常量池中没有,就在常量池中建立一个对象”abc”,第二次建立的时候,就直接使用,因此两次建立的对象实际上是同一个对象,它们的地址值相等。内存

那上一个例子中的源码

String str1 = new String("abc");

是怎么回事呢? 
这里其实建立了两次对象,因此str1和str2的地址值不相等。hash

相关文章
相关标签/搜索