相等操作符由于原始类型时比较的是它们的值。而用于对象时比较的是对象的引用而不是对象的实际内容。 您可能问:"这些引用都指向同一个对象么?" 为了说明清晰,请看下面只含有 tag 和 age 的 Dog 的又一版本:
class Dog {int tag;int age;public void setTag(int t) {tag=t;}public void setAge(int a) {age=a;}}
如果有两只狗(dog),即使它们的内容都相同,用 == 操作符时它们并不相等。下面代码段的输出表明在用 "==" 时 a 和 b 并不相等:
Dog a = new Dog();a.setTag(23129);a.setAge(7);Dog b = new Dog();b.setTag(23129);b.setAge(7);if ( a==b ) {System.out.println("a is equal to b");}else {System.out.println("a is not equal to b");}
那么,应该怎么比较两个对象的值而不是比较它们的引用呢?Java(TM) 编程语言有一个约定,方法 equals() 用来定义对象值相等。 类 Object 中定义了方法equals(),如果在其子类中没有被重载,那么默认使用的就是它。 为了比较两只狗(dog) a 和 b 的值,你应该重写上面的比较部分:
if ( a.equals(b) ) {System.out.println("a is equals() to b");}else {System.out.println("a is not equals() to b");}
上面的代码中,如果在 Dog 中没有重载 equals() 方法,两只狗依旧不等。因为 Object.equals() 实际模拟的是 == 操作符的功能。 Dog 中 equals() 的定义很好懂:
class Dog {int tag;int age;public void setTag(int t) {tag=t;}public void setAge(int a) {age=a;}public boolean equals(Object o) { Dog d = (Dog)o; if ( tag==d.tag && age==d.age ) {return true; } return false;}}
但是,由于 equals() 是在 Dog 中定义的,你必须检查传入的对象是否是一只 Dog,因为有人可能这样用:
fido.equals("blort");
字符串 "blort" 也是一个 Object ,因此与 Dog 中 equals() 的标记是匹配的。equals() 的正确写法是:
public boolean equals(Object o) {if ( o instanceof Dog ) { Dog d = (Dog)o; if ( tag==d.tag && age==d.age ) {return true; }}// false if not Dog or contents mismatchedreturn false;}