Java将此类与该类进行比较以获得相等性

时间:2013-05-10 03:04:18

标签: java compare equality

我的任务是覆盖方法equals()。我使用Stack12<E> that = (Stack12<E>)o;o instanceof Stack12时遇到了一些问题。我很奇怪他们是不好的练习,特别是我在for-loop中使用that的方式对我来说有点不合适。

有没有其他方法可以将此类与其他对象进行比较?或者我的比较方法是否足够强大?

  public boolean equals(java.lang.Object o){
  if(o == this) return true;
  if(o == null || !(o instanceof Stack12)){
     return false;
  }

  Stack12<E> that = (Stack12<E>)o;
  if(this.size != that.size || this.capacity != that.capacity ){
     return false;
  }
  for(int i = 0; i < this.size; i++){
     if( that.stack[i] != this.stack[i] ){
        return false;
     }
  }
  return true;
 }

1 个答案:

答案 0 :(得分:5)

我要添加的一个警告是,无论何时覆盖equals(...),您还需要覆盖hashCode()。我同意看到过度使用的例子让我担心代码味道,但我认为你别无选择,只能在这种情况下使用instanceof。至于转换为通用类型,我可能是错的,但在运行时,泛型确实不存在,所以它可能没有实际意义。

我看到的一个潜在的主要问题是您在for循环中使用==。如果堆栈数组使用对象,则应在循环内使用equals(...)。您的类是通用的这一事实表明堆栈数组确实存放了对象,但我不确定,因为我们没有看到这一点。