首先看下面两个例子
public class Test {
public static void main(String[] args) {
Integer n1 = new Integer(10);
Integer n2 = new Integer(10);
System.out.println(n1==n2);
System.out.println(n1.equals(n2));
}
}
运行结果是false,true。
分析一下,"=="是比较两个对象是否为同一个引用,n1和n2是两个不同的对象引用,而equals方法则比较的是两个对象的值是否相同。
对比
public class Test {
public static void main(String[] args) {
Integer v1 = 1;
Integer v2 = 1;
System.out.println(v1==v2);
System.out.println(v1.equals(v2));
}
}
运行结果就是true,true。因为虚拟机中Integer对象"1"只有一个(在上个例子中用new,相当于又复制了一个Integer对象),v1和v2都是对同一个对象的引用
再看下面例子
class Value{
int data;
}
public class Test {
public static void main(String[] args) {
Value v1 = new Value();
Value v2 = new Value();
v1.data = v2.data = 1;
System.out.println(v1==v2);
System.out.println(v1.equals(v2));
}
}
运行结果是false,false
第一个false很好理解,第二个false是因为equals 方法其实是调用每个类自己的equals方法去比较,需要用自定义的equals进行覆盖
下面程序的结果就是可以想象的了
class Value{
int data;
//使用eclipe自动生成
@Override
public boolean equals(Object obj) {
//如果比较的对象时自己,则返回true
if (this == obj)
return true;
//如果比较的对象不存在,则返回false
if (obj == null)
return false;
//如果两个对象的类不一样,则返回false.可以用instance of代替
if (getClass() != obj.getClass())
return false;
Value other = (Value) obj;
//标志数据
if (data != other.data)
return false;
return true;
}
}
public class Test {
public static void main(String[] args) {
Value v1 = new Value();
Value v2 = new Value();
v1.data = v2.data = 1;
System.out.println(v1==v2);
System.out.println(v1.equals(v2));
}
}
运行结果false,true