J'ai donc de nombreuses classes personnalisées qui ont également des classes personnalisées à l'intérieur d'elles en utilisant la composition.
Mes classes personnalisées ont des variables qui changent très fréquemment et je les ajoute aux HashSets. Ma question est donc la suivante : lorsque j'implémente hashCode - que dois-je faire pour une classe qui n'a que des champs privés qui changent constamment ?
Voici un exemple d'une classe personnalisée :
public class Cell {
protected boolean isActive;
protected boolean wasActive;
public Cell() {
this.isActive = false;
this.wasActive = false;
}
// getter and setter methods...
@Override
public int hashCode() {
// HOW SHOULD I IMPLEMENT THIS IF THIS custom object is constantly
// being added into HashSets and have it's private fields isActive
// and wasActive constantly changed.
}
// ANOTHER QUESTION Am I missing anything with this below equals implementation?
@Override
public boolean equals(Object object) {
boolean result = false;
if (object instanceof Cell) {
Cell otherCell = (Cell) object;
result = (this.isActive == otherCell.isActive && this.wasActive ==
otherCell.wasActive);
}
return result;
}