首先,Java中的==比较的是两个对象的引用的地址是否一样,如下:
Person a = new Person();
Person b = new Person();
Person c = a;
System.out.print(a==b);
System.out.print(a==c);
执行结果为
false
true
代码分析一波:
程序先是在JVM中创建了两个Person对象,分别将引用地址赋予a和b,然后c其实并没有创建新的Person对象,只是将a指向的那个对象又创建一份引用地址赋予c,因此a和c指向的是同一个对象。接下来就是本篇博客的重头戏了,我将详细为大家介绍许多童鞋困惑的==和equals的区别。
在Java的终极父类Object类中,equals调用的就是==,因此所有未重写equals方法的类在比较时使用equals和==是一样的结果。
源码如下:
public boolean equals(Object obj) {
return (this == obj);
}
既然equals最终也是调用==,那么为什么我们在实际开发中会遇到两者结果不一样的情况呢?这是因为这些对象自己或者其父类重写了equals方法,比如最常用的String对象,它就重写了equals方法:
public boolean equals(Object anObject) {
if (this == anObject) {
return true;
}
if (anObject instanceof 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;
}
通过重写方法,当我们对String类型的对象进行equals比较时,就是比较字符串的内容是否相同了。
类似String类型重写equals方法的还有Java的8中基本数据类型的包装类(注意是包装类,基本数据类型病布恩那个使用equals方法进行比较),以int的包装类Integer为例:
public boolean equals(Object obj) {
if (obj instanceof Integer) {
return value == ((Integer)obj).intValue();
}
return false;
}
总结: