我有一个POJO,在我所定义的hashCode方法我认为是的..正确实现hashCode()方法
public int hashCode()
{
return name.hashCode()+job.hashCode()+salary;
}
但因为我使用的Eclipse IDE,它也提供了我的自动生成散列码,其是..
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((job == null) ? 0 : job.hashCode());
result = prime * result + ((name == null) ? 0 : name.hashCode());
result = prime * result + salary;
return result;
}
现在我的疑问是,这两个之间的差异,哪一个实现更好.. ..!我完全POJO是...
enter codepackage CollectionsPrac;
公共类Employee {
String name,job;
int salary;
public Employee(String n , String j, int t)
{
this.name= n;
this.job=j;
this.salary= t;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((job == null) ? 0 : job.hashCode());
result = prime * result + ((name == null) ? 0 : name.hashCode());
result = prime * result + salary;
return result;
}
/*@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Employee other = (Employee) obj;
if (job == null) {
if (other.job != null)
return false;
} else if (!job.equals(other.job))
return false;
if (name == null) {
if (other.name != null)
return false;
} else if (!name.equals(other.name))
return false;
if (salary != other.salary)
return false;
return true;
}
*/
/* @Override
public int hashCode()
{
return name.hashCode()+job.hashCode()+salary;
}*/
@Override
public boolean equals(Object obj) {
if (this == obj)
{
return true;
}
// make sure o can be cast to this class
if (obj == null || obj.getClass() != getClass())
{
// cannot cast
return false;
}
Employee e = (Employee) obj;
return this.name.equals(e.name)&&this.job.equals(e.job)&&this.salary==e.salary;
}
@Override
public String toString() {
return name+"\t" +"\t"+ job +"\t"+ salary;
}
} 这里
嗨,所以请你告诉我我的hashcode()实现有什么问题。!1 – Neera 2012-04-15 18:06:35
你的版本比Eclipse的版本产生更多(错误)散列冲突。 – 2012-04-15 18:13:17
@ user1334074:查看我的更新。基本上希望'hashCode()'应该为稍微不同的对象返回不同的结果。 – 2012-04-15 18:16:15