Как мне реализовать hashCode()
и equals()
для следующего класса в Java?
class Emp
{
int empid ; // unique across all the departments
String name;
String dept_name ;
String code ; // unique for the department
}
Как мне реализовать hashCode()
и equals()
для следующего класса в Java?
class Emp
{
int empid ; // unique across all the departments
String name;
String dept_name ;
String code ; // unique for the department
}
в Eclipse правой кнопкой мыши → source → generate hashCode() и equals() дает следующее:
/* (non-Javadoc)
* @see java.lang.Object#hashCode()
*/
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + (code == null ? 0 : code.hashCode());
return result;
}
/* (non-Javadoc)
* @see java.lang.Object#equals(java.lang.Object)
*/
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (!(obj instanceof Emp))
return false;
Emp other = (Emp) obj;
return code == null ? other.code == null : code.equals(other.code);
}
Я выбрал код как уникальное поле
попробуйте этот код, используйте org.apache.commons.lang3.builder
public int hashCode() {
return new HashCodeBuilder(17, 31). // two randomly chosen prime numbers
append(empid).
append(name).
append(dept_name ).
append(code ).
toHashCode();
}
public boolean equals(Object obj) {
if (obj == this)
return true;
if (!(obj instanceof Person))
return false;
Emp rhs = (Emp) obj;
return new EqualsBuilder().
// if deriving: appendSuper(super.equals(obj)).
append(name, rhs.name).
isEquals();
}
Гува имеет вспомогательные методы для их создания. Вы указываете, какие поля принимать во внимание, и он будет обрабатывать нули для вас и делать вычисление простых чисел для hashcode.
IDE также могут генерировать их на основе выбранных вами полей.
Преимущество делегирования его на такой инструмент - вы получаете стандартное решение и будете меньше беспокоиться о ошибках и обслуживании разнообразных реализаций, распространенных по всему вашему проекту.
Вот пример использования Guava и сгенерированный плагином IntelliJ: https://plugins.jetbrains.com/plugin/7244?pr=
Если код уникален (т.е. ваш бизнес-ключ), лучше всего использовать код для equals и hashCode - это хорошая практика для разделения бизнес-ключа (кода) от идентификатора объекта (id).
Здесь приятно читать: Hibernate Documentation: Equals и HashCode (действителен не только для самого Hibernate)
какие значения, которые вы используете, равны, чтобы определить, являются ли два объекта одинаковыми, являются значения, которые необходимо использовать для создания хеш-кода.
public boolean equals(Object o) {
boolean result = false;
if(o instanceof CategoryEnum) {
CategoryEnum ce = (CategoryEnum) o;
result = ce.toString().equals(name);
}
return result;
}
public int hashCode()
{
int hash = 6;
hash += 32 * name.hashCode();
return hash;
}
equals() и hashcode(), у них много разных мест. equals(), если мы не переопределяем его из Object, это означает, что две переменные указывают на одну и ту же кучу объекта?
public Class Student(){
private int id;
private name;
public Student(int id,String name){
this.name=name;
this.id=id;
}
public void main(String[] args){
Student A=new Student(20,'Lily');
Student B=new Student(20,'Lily');
boolean flag=A.equals(B)//flag=flase;
/*
*Although they attribute the same, but they are two different objects, they point to different memory
*/
@Override
public boolean equals(Object obj) {
if (obj == null) {
return false;
}
if (this == obj) {
return true;
}
if (this.getClass() != obj.getClass()) {
return false;
}
Student s=(Student)obj;
return new Integer(this.id).equals(new Integer(s.id))&&this.name.equals(s.name);
}
/**
*Sometimes even though we Override the equals, but we still can not determine whether the *two objects the same,
*In the collection object, such as HashSet, this time we have to Override the hashoCode ()
*/
public int hashCode(){
return id + name.hashCode() ;
}