如果隐式和显式参数不属于同一个类,对于equals函数,有些采用instanceof方法,这回忽略子类的情况:
instanceof是Java中的一个运算符,用于判断一个对象是否是某个类的实例或者是其子类的实例。它的语法是:对象 instanceof 类名。这个运算符返回一个布尔值,如果对象是该类的实例或者其子类的实例,则返回true,否则返回false。比如,如果一个引用变量test的编译时类型是Object,实际类型是String,那么test instanceof Object将返回true,因为test可以是Object类的实例;test instanceof String也将返回true,因为Object是String的父类;而test instanceof Math将返回false,因为test不是Math类的实例。
一般会采用getClass(),getClass会返回类名即字符串,用两个字符串进行比较是正确的;
散列码:
散列码是由对象导出的一个整型值,如果x,y是两个不同的对象,那么x.hashCode()和y.hashCode()基本不同,hashCode定义在object里,每一个对象都会有一个默认的散列码,其值为对象的存储地址(指针值),而有些类有自己定义的hashCode(),如String,那他的散列码就不是地址值,因此String对象的散列码有可能相同,但没有定义hashCode()的类的对象的散列码肯定不同,如StringBuilder。
如果要重新定义equals,就必须重新定义hashCode(),并合理的组合属性变量的散列码。重新定义的散列码其实就是随机数;其实采用object类的hashCode方法就很好;
object类中的toString方法类似于cout,,将输出对象所属的类名和散列码,获取类名的方法:
getClass().getName();
为了简单,子类可以直接调用父类的方法,
如果x是任意一个对象,那么System.out.println(x)将会调用x.toString();并打印得到的字符串,即重载;编译器如果看到“”+x,将调用x.toString();
Employee x=new Employee();System.out.print(x);Employee@35fb3008
令人烦恼的是,数组类继承了object的toString方法,数组类型将按照object的方法打印数组的指针地址和数组名;要让数组可以向字符串一样被打印,可以调用Arrays.toString();
总结:hashCode(),equals(),toString()是object定义的三种方法,其他类如果要重新定义,则需要同时重新定义hashCode()和equals(),Java编译器会在某些函数中自动调用toString();
getClass(),getSuperclass():返回当前类,父类的信息;getClass的返回对象并不是字符串,我们可以理解为内联函数或者宏替换,因为他有时甚至可以调用方法;