Object类是Java中所有类的最终祖先,在Java中,每个类都是由它扩展而来的,但是并不需要这样写:
class Employee extends Object
如果没有明确地指出超类,Object就被认为是这个类的最终超类。可以使用Object类型的变量引用任何类型的对象:
Object obj = new Employee("Harry Hacker",35000);
当然,Object类型变量只能用于作为各种值的通用持有者。要想对它们进行特定的操作,还需要清楚对象的原始类型,并进行相应的类型转换:
Employee e = (Employee)obj;
在Java中,只有基本类型(primitive type,如数值、字符、和boolean)的值不是对象,而所有的数组类型,不管是对象数组还是基本类型的数组都扩展于Object类的类型。
5.2.1 equals方法
Object类中equals方法用于检测一个对象是否等于另外一个对象。如果两个对象具有相同的引用,它们一定是相等的。
Java语言规范要求equals方法具有下面的特性:
1)自反性:对于任何非空引用x,x.equals(x)应该返回true。
2)对称性:对于任何非空引用x和y,如果x.equals(y)返回true,那么y.equals(x)也应该返回true。
3)传递性:对于任何非空应用x、y和z,如果x.equals(y)返回true,y.equals(z)返回true,那么x.equals(z)也应该返回true。
4)一致性:如果x和y引用的对象没有发生变化,那么反复调用x.equals(y)应该返回同样的结果。
5)对于任意非空引用x,x.equals(null)应该返回false。
下面给出编写一个完美的equals方法的建议:
1)显示参数命名为otherObject,稍后需要将它转换成另一个叫做other的变量。
2)检测this与otherObject是否引用同一个对象:
if(this == otherObject) return true;
3)检测otherObject是否为null,如果为null,返回false。
if(otherObject == null) return false;
比较this与otherObject是否属于同一个类。如果equals的语义在每个子类中有所改变,就使用getClass检测:
if(getClass()!=otherObject.getClass()) return false;
如果所有的子类都拥有统一的语义,就使用instanceof检测:
if(!(otherObject instanceof ClassName)) return false;
4) 将otherObject转换为相应的类类型变量:
ClassName other = (ClassName)otherObject
5)现在开始对所有需要比较的域进行比较了。使用 == 比较基本类型域,使用equals比较对象域。如果所有的域都匹配,就返回true,否则返回false。
return field1==other.field1
&&field2.equals(other.field2)
&&...;
如果在子类中重新定义equals,就要在其中包含调用super.equals(other)。
最后关于重写equals,还有一个最重要的说明:要重写HashCode。对于 eauals 与hashcode的宣言要必须一致。
摘自《Java核心技术》
class Employee extends Object
如果没有明确地指出超类,Object就被认为是这个类的最终超类。可以使用Object类型的变量引用任何类型的对象:
Object obj = new Employee("Harry Hacker",35000);
当然,Object类型变量只能用于作为各种值的通用持有者。要想对它们进行特定的操作,还需要清楚对象的原始类型,并进行相应的类型转换:
Employee e = (Employee)obj;
在Java中,只有基本类型(primitive type,如数值、字符、和boolean)的值不是对象,而所有的数组类型,不管是对象数组还是基本类型的数组都扩展于Object类的类型。
5.2.1 equals方法
Object类中equals方法用于检测一个对象是否等于另外一个对象。如果两个对象具有相同的引用,它们一定是相等的。
Java语言规范要求equals方法具有下面的特性:
1)自反性:对于任何非空引用x,x.equals(x)应该返回true。
2)对称性:对于任何非空引用x和y,如果x.equals(y)返回true,那么y.equals(x)也应该返回true。
3)传递性:对于任何非空应用x、y和z,如果x.equals(y)返回true,y.equals(z)返回true,那么x.equals(z)也应该返回true。
4)一致性:如果x和y引用的对象没有发生变化,那么反复调用x.equals(y)应该返回同样的结果。
5)对于任意非空引用x,x.equals(null)应该返回false。
下面给出编写一个完美的equals方法的建议:
1)显示参数命名为otherObject,稍后需要将它转换成另一个叫做other的变量。
2)检测this与otherObject是否引用同一个对象:
if(this == otherObject) return true;
3)检测otherObject是否为null,如果为null,返回false。
if(otherObject == null) return false;
比较this与otherObject是否属于同一个类。如果equals的语义在每个子类中有所改变,就使用getClass检测:
if(getClass()!=otherObject.getClass()) return false;
如果所有的子类都拥有统一的语义,就使用instanceof检测:
if(!(otherObject instanceof ClassName)) return false;
4) 将otherObject转换为相应的类类型变量:
ClassName other = (ClassName)otherObject
5)现在开始对所有需要比较的域进行比较了。使用 == 比较基本类型域,使用equals比较对象域。如果所有的域都匹配,就返回true,否则返回false。
return field1==other.field1
&&field2.equals(other.field2)
&&...;
如果在子类中重新定义equals,就要在其中包含调用super.equals(other)。
最后关于重写equals,还有一个最重要的说明:要重写HashCode。对于 eauals 与hashcode的宣言要必须一致。
摘自《Java核心技术》