首先看下面两个例子
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