hashCode方法優(yōu)化:
- 如果讓hashCode()方法返回一個(gè)固定值,那么每個(gè)新添加的元素都要調(diào)用equals(Object obj)方法比較,那么效率較低
- 只需要讓不同屬性的值的元素產(chǎn)生不同的哈希值,那么就可以不再調(diào)用equals方法比較提高效率
package com.itheima_02;
public class Person {
String name;
int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public String toString() {
return "Person [name=" + name + ", age=" + age + "]";
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + age;
result = prime * result + ((name == null) ? 0 : name.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Person other = (Person) obj;
if (age != other.age)
return false;
if (name == null) {
if (other.name != null)
return false;
} else if (!name.equals(other.name))
return false;
return true;
}
/* @Override
public boolean equals(Object obj) {
System.out.println("--------");
//提高效率
if(this == obj) {
return true;
}
//提高程序健壯性
if(this.getClass() != obj.getClass()) {
return false;
}
//向下轉(zhuǎn)型
Person p = (Person)obj;
if(this.name.equals(p.name)) {
return false;
}
if(this.age != p.age) {
return false;
}
return true;
}*/
}
package com.itheima_02;
import java.util.HashSet;
public class HashSetDemo {
public static void main(String[] args) {
//創(chuàng)建集合對(duì)象
HashSet<Person> hs = new HashSet<Person>();
//創(chuàng)建元素對(duì)象
Person p = new Person("zhangsan",18);
Person p2 = new Person("lisi",19);
Person p3 = new Person("lisi",19);
//添加元素對(duì)象
hs.add(p);
hs.add(p2);
hs.add(p3);
//遍歷集合
for (Person person : hs) {
System.out.println(person);
}
}
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。