HashCode方法和equals方法的优化

1.首先新创建一个Person类

public class Person {

String name;

int age;

public Person(String name,int age){

this.name=name;

this.age=age;

}

public String toString() {

return "Student [name=" + name + ", age=" + age + "]";

}

//重写hashCode方法

public int hashCode() {

return age+name.hashCode();

}

//重写equals方法

public boolean equals(Object obj) {  //如果元素相等则返回true,不予以添加

//提高效率,例如,如果传进来的都是同一个对象,那么地址值就肯定一样,

//就没必要去比较了,所以要做以判断,判断这两个对象是否一样.

if(this == obj){

return true;

}

//提高健壮性,例如,如果对象的类型都不一样,那也就没必要向下转型了,

//如何去判断对象的类型呢?对象的类型一样即就是说明这两个对象在同一个class文件下,

//所以我们可以通过比较两个对象的类名来确定类型是否一样

if(this.getClass()!=obj.getClass()){

return false;

}

//向下转型

Person p = (Person)obj;

if(!this.name.equals(p.name)){

return false;

}

if(this.age!=p.age){

return false;

}

return true;

}

}

你可能感兴趣的:(HashCode方法和equals方法的优化)