Подтвердить что ты не робот

Как реализовать метод hashCode и equals

Как мне реализовать hashCode() и equals() для следующего класса в Java?

class Emp 
{
  int empid ; // unique across all the departments 
  String name;
  String dept_name ;
  String code ; // unique for the department 
}
4b9b3361

Ответ 1

в 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);
}

Я выбрал код как уникальное поле

Ответ 2

попробуйте этот код, используйте 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();
}

Ответ 3

Гува имеет вспомогательные методы для их создания. Вы указываете, какие поля принимать во внимание, и он будет обрабатывать нули для вас и делать вычисление простых чисел для hashcode.

IDE также могут генерировать их на основе выбранных вами полей.

Преимущество делегирования его на такой инструмент - вы получаете стандартное решение и будете меньше беспокоиться о ошибках и обслуживании разнообразных реализаций, распространенных по всему вашему проекту.

Вот пример использования Guava и сгенерированный плагином IntelliJ: https://plugins.jetbrains.com/plugin/7244?pr=

Ответ 4

Если код уникален (т.е. ваш бизнес-ключ), лучше всего использовать код для equals и hashCode - это хорошая практика для разделения бизнес-ключа (кода) от идентификатора объекта (id).

Здесь приятно читать: Hibernate Documentation: Equals и HashCode (действителен не только для самого Hibernate)

Ответ 5

какие значения, которые вы используете, равны, чтобы определить, являются ли два объекта одинаковыми, являются значения, которые необходимо использовать для создания хеш-кода.

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;
}   

Ответ 6

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() ;
}