应用于Vector的equals()不一致

时间:2009-12-16 19:43:26

标签: java equals

Vector <Double> x = new Vector<Double>();
Vector <Integer> y = new Vector <Integer>();  
System.out.print(x.equals(y));

打印:

true

为什么呢?不是equals() - 默认 - 如果两个引用指向同一个对象,应该比较吗?

3 个答案:

答案 0 :(得分:6)

equals已在AbstractList中实施。它遍历列表中的元素,如果不相等则返回false。因为您的列表没有元素,所以返回true。

public boolean equals(Object o) {
if (o == this)
    return true;
if (!(o instanceof List))
    return false;

ListIterator<E> e1 = listIterator();
ListIterator e2 = ((List) o).listIterator();
while(e1.hasNext() && e2.hasNext()) {
    E o1 = e1.next();
    Object o2 = e2.next();
    if (!(o1==null ? o2==null : o1.equals(o2)))
    return false;
}
return !(e1.hasNext() || e2.hasNext());
}

正如Tom在评论中提到的,阅读List接口的合同,您将看到它定义了行为。

  

当且仅当指定的对象也是列表时,返回true,两个列表具有相同的大小,并且两个列表中的所有对应元素对都相等。

答案 1 :(得分:2)

NO,如果两个引用指向同一个对象,则不应该比较equals() 它会比较引用的对象是相等,大​​多数情况下意味着具有相同的内容。

如果没有为给定的Object实现该方法,它只会比较同一个对象。在这种情况下,只需使用Object运算符即可使用==中的方法。

==是比较它是否是同一个对象(实例)的那个。

答案 2 :(得分:1)

Vector有自己的equals方法。它比较了它的内容。你的Vector都是空的,所以它们是平等的。

请注意:由于运行时类型擦除,只有两个Vector实例。