java – 在equals()方法中测试泛型类型

我有以下课程.

public class Combination<E extends Comparable> {

    private List<E> objects;

    // ...

    @Override
    public boolean equals(Object o) {
        // ...
    }

    @Override 
    public int hashCode() {
        // ...
    }
}

我重写了equals和hashCode方法,因此我可以轻松地创建一个Set< Combination>并没有任何多余的组合.

问题是……因为我的类有一个泛型类型,我如何在我的equals方法中测试这个类型?例如,组合<整数>与组合< Double>不同或组合< Car>.但是如何在equals方法中测试呢?

理想情况下,我可以覆盖equals方法以接受组合< E>参数.一个简单的解决方案是重载equals方法吗?例如,

@Override
public boolean equals(Object o) {
    // This method will only be called when o is not an instance of Combination<E>.
    // So in this case return false.
    return false;
}

public boolean equals(Combination<E> cmb) {
    // Compare the two combinations here.
    // <code> ...
}

解决方法

这里的解决方案是信任成员对象的equals方法只匹配正确的类型.你需要在这里使用instanceof,你不应该使用rawtypes,但它应该看起来像

@Override public boolean equals(Object o) {
  if (o instanceof Combination) {
    Combination<?> c = (Combination<?>) o;
    return objects.equals(c.objects);
  }
  return false;
}

这是类型安全的并且工作正常,并且信任List(及其元素)以正确实现它们自己的equals方法.

相关文章

HashMap是Java中最常用的集合类框架,也是Java语言中非常典型...
在EffectiveJava中的第 36条中建议 用 EnumSet 替代位字段,...
介绍 注解是JDK1.5版本开始引入的一个特性,用于对代码进行说...
介绍 LinkedList同时实现了List接口和Deque接口,也就是说它...
介绍 TreeSet和TreeMap在Java里有着相同的实现,前者仅仅是对...
HashMap为什么线程不安全 put的不安全 由于多线程对HashMap进...