AbstractList 重写 equals() 方法

2019-01-10 07:48:55来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

题目内容

题目内容很简单,就是创建 ArrayList 和 Vector 集合,向两者添加相同内容的字符串,最后用 equals() 方法比较是否相等。

这里就考察了 "==" 和 equals() 方法的知识点。

这里我最开始以为输出为 false,但实验了一下,结果为 true!

为什么呢?因为我不知道 ArrayList 和 Vector 的共同父类 AbstractList 重写了 Object 类的 equals() 方法

重写方法体如下:

public boolean equals(Object o) {  
   // 这里利用 == 判断两个集合是否为同一引用同一地址,因为是 == 比较的
if (o == this) return true;
// 这里判断比较集合是否为 List 的实例,如果不是直接返回 false
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();
// 这里的比较规则如下:
     //   1. 两者元素其中一个为 null, 但另一个不为 null, 则返回 false
//   2. 其中一个元素不为 null, 但两者使用 equals() 方法比较为 false, 则返回 false
if (!(o1==null ? o2==null : o1.equals(o2))) return false; }
   // 集合元素变量完之后,且循环体没有返回 flase, 则 如果任意一个集合还有元素则返回 false
return !(e1.hasNext() || e2.hasNext()); }

由于题目中集合的泛型为 String,而 String 也重写了 equals() 方法,所以,题目中的集合内容也是相同的,即比较结果为 true。

如果元素内容为其他的,且没有重写 equals() 方法,那么比较结果就为 false。

如:

public void test() {
    StringBuilder sb = new StringBuilder("demo");
    StringBuilder sb1 = new StringBuilder("demo");

    ArrayList<StringBuilder> arrayList = new ArrayList<StringBuilder>();
    arrayList.add(sb);

    Vector<StringBuilder> vector = new Vector<StringBuilder>();
    vector.add(sb1);

System.out.println(arrayList.equals(vector)); }

补充:

  很多人并不知道 Integer 类也重写了 equals() 方法

public boolean equals(Object obj) {
    if (obj instanceof Integer) {
//这里很明显,看似使用 == 比较,但是调用了 intValue() 方法返回 int 类型,所以就是使用 == 比较基本数据类型,比较的也就是值是否相等了
return value == ((Integer)obj).intValue(); } return false; }

public int intValue() {
  return value;
}

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:Java 注解原理

下一篇:50道Java线程面试题