昨天遇到对象去重问题,想当然用Set存储对象,debug的时候发现个数还是没变,所有的都存进来了,百度了一会发现Set是需要重写equals和hashcode的。
@Override
public boolean equals(Object obj) {
if(this==obj){
return true;
}
if(obj==null)
return false;
if(obj.getClass()!=this.getClass()){
return false;
}
PubNumberFamilyTemp p= (PubNumberFamilyTemp) obj;
if(Objects.equals(patentNumber,p.getPatentNumber())
&& Objects.equals(kind,p.getKind())
&& Objects.equals(date1,p.getDate1())
&& Objects.equals(date2,p.getDate2())
&& Objects.equals(applicationNumber,p.getApplicationNumber())
&& Objects.equals(code,p.getCode())){
return true;
}else{
return false;
}
}
这里一开始用kind.equals(p.getKind())&&与上几个字段的相等条件,结果会报错,用Objects.equals(kind,p.getKind())是正常的。
重写equlas也要重写hashcode,需要注意的是,hashcode的判同条件和equals是一样的。
@Override
public int hashCode() {
return Objects.hash(patentNumber,kind,date1,date2,applicationNumber,code);
}
个人觉得Objects.hash比一个个的字段乘以值要方便快捷的多。
这样用Set<该对象>的时候,往里面添加对象,遇到这几个字段一样的对象,就覆盖之前的,以此保证唯一性。