一、首先,我们给出一个实例
package day10_9;
public class equalsDemo {
public static void main(String[] args) {
Person p1 =new Person(18);
Person p2 =new Person(18);
System.out.println(p1.equals(p2));
}
}
class Person{
private int age;
public Person(int age) {
this.age = age;
}//the function of a constructor is to initialize the Object
public boolean equals(Object obj) {
if(obj instanceof Person) {
return this.age == ((Person)obj).age;
}
return false;
}
}
输出的结果为
true
从上面的例子我们可以看出我们自己定义了一个Person类,定义了一个私有的age变量,通过一个构造方法对age初始化。其次复写了超级父类Object类中的equals方法。我们可以看到,这里我们要比较的是两个 Person对象的age,如果两个Person对象p1和p2的年龄相同,那么,此时返回的就是true,否则返回的就是false。
二、现在我们还是比较Person类,但此时我们不复写Object类中的equals方法,直接使用继承下来的Object类中的equals方法。
package day10_9;
public class equalsDemo {
public static void main(String[] args) {
Person p1 =new Person(18);
Person p2 =new Person(18);
System.out.println(p1.equals(p2));
}
}
class Person{
private int age;
public Person(int age) {
this.age = age;
}//the function of a constructor is to initialize the Object
}
输出的结果
false
从上面的代码我们可以看到,Person类中并没有定义equals方法,那么是从哪来的呢??其实就是每一个类都会继承java.lang中的Object类中的equals方法,代码如下:
public boolean equals(Object obj){
return (this == obj);
}
从上面的代码也可以看出,如果equals方法不进行复写的话,那么比较的就是两个对象的引用是否相同,也就是两个地址是否相同。此时的equals()方法和==是一样的功能。
本文通过两个实例详细解析了Java中自定义类的equals方法。首先介绍了如何覆盖equals方法以比较对象的状态(如年龄),并展示了当未覆盖equals方法时,默认行为是比较对象引用。
6690

被折叠的 条评论
为什么被折叠?



