Si dos objetos devuelven el mismo código hash, ¿no significa que son iguales? ¿O necesitamos iguales para evitar colisiones?
¿Y puedo implementar iguales comparando hashCodes?
Si dos objetos tienen el mismo código hash, NO son necesariamente iguales. De lo contrario, habrás descubierto la función hash perfecta. Pero lo contrario es cierto: si los objetos son iguales, entonces deben tener el mismo código hash.
hashCode y Equals son información diferente sobre objetos
Considere la analogía con Personas donde el código hash es el Cumpleaños,
en ese escenario, usted y muchas otras personas tienen el mismo cumpleaños (mismo código hash), sin embargo, no todos son la misma persona ...
El método hashCode , como se indica en Oracle Docs, es una representación numérica de un objeto en Java. Este código hash tiene valores posibles limitados (representados por los valores que se pueden almacenar en un int).
Para una clase más compleja, existe una alta posibilidad de que encuentre dos objetos diferentes que tengan el mismo valor de código hash. Además, nadie te impide hacer esto dentro de cualquier clase.
class Test { @Override public int hashCode() { return 0; } }
Por lo tanto, no se recomienda implementar el método de igualdad comparando códigos hash. Debe usarlos para comparar solo si puede garantizar que cada objeto tiene un código hash único. En la mayoría de los casos, su única certeza es que si dos objetos son iguales usando o1.equals(o2) entonces o1.hashCode() == o2.hashCode() .
En el método equals puedes definir una lógica más compleja para comparar dos objetos de la misma clase.