题目内容

题目内容很简单,就是创建 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;
}

AbstractList 重写 equals() 方法的更多相关文章

  1. Effective Java 第三版——10. 重写equals方法时遵守通用约定

    Tips <Effective Java, Third Edition>一书英文版已经出版,这本书的第二版想必很多人都读过,号称Java四大名著之一,不过第二版2009年出版,到现在已经将 ...

  2. java重写equals方法

    @Override public int hashCode() { return task.getId(); } @Override public boolean equals(Object obj) ...

  3. 重写equals()方法时,需要同时重写hashCode()方法

    package com.wangzhu.map; import java.util.HashMap; /** * hashCode方法的主要作用是为了配合基于散列的集合一起正常运行,<br/&g ...

  4. 为什么重写equals方法还要重写hashcode方法?

    我们都知道Java语言是完全面向对象的,在java中,所有的对象都是继承于Object类.Ojbect类中有两个方法equals.hashCode,这两个方法都是用来比较两个对象是否相等的. 在未重写 ...

  5. 为什么要重写equals()方法与hashCode()方法

    在java中,所有的对象都是继承于Object类.Ojbect类中有两个方法equals.hashCode,这两个方法都是用来比较两个对象是否相等的. 在未重写equals方法我们是继承了object ...

  6. C#中在比较自定义对象的时候要重写Equals方法

    using System;using System.Collections.Generic;using System.Text; namespace Equal{    using System; c ...

  7. 为什么重写 equals 方法 必须重写 hashCode

    自己学到这,就记录了下来,代码都是自己敲得,有不对的地方希望大神指点出来 为什么重写 equals 方法 必须重写 hashCode 如果你重写了equals,比如说是基于对象的内容实现的,而不重写 ...

  8. Effective Java 第三版——11. 重写equals方法时同时也要重写hashcode方法

    Tips <Effective Java, Third Edition>一书英文版已经出版,这本书的第二版想必很多人都读过,号称Java四大名著之一,不过第二版2009年出版,到现在已经将 ...

  9. java开发----自定义对象,重写equals方法

    javaweb开发中,用到了好多自定义对象,这时候如果不重写equals方法,很多时候都会返回false, 因此我们必须习惯重写这个方法. 重点: 1.equals比较俩对象时比较的是对象引用是否指向 ...

随机推荐

  1. [Usaco2018 Open]Milking Order

    Description Farmer John的N头奶牛(1≤N≤10^5),仍然编号为1-N,正好闲得发慌.因此,她们发展了一个与Farmer John每天早上为她们挤牛奶的时候的排队顺序相关的复杂 ...

  2. hdu6195 cable cable cable

    cable cable cable Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others ...

  3. Android 性能优化(23)*性能工具之「Heap Viewer, Memory Monitor, Allocation Tracker」Memory Profilers

    Memory Profilers In this document Memory Monitor Heap Viewer Allocation Tracker You should also read ...

  4. pip安装itchat模块成功后annocanda中No module named 'itchat'

    在cmd中pip install itchat 成功后在annocanda中却出现了下面的情况: 经过查找网上各种查询,原来pip默认是把东西安装在系统python环境中,即C:\Python27\L ...

  5. poj2367 Genealogical tree

    思路: 拓扑排序,这里是用染色的dfs实现的.在有环的情况下可以判断出来,没有环的情况下输出拓扑排序序列. 实现: #include <vector> #include <cstri ...

  6. HTML5——移动端的点击、拖拽

    移动端浏览器不支持mouse事件 https://www.cnblogs.com/joyco773/p/6519668.html https://www.cnblogs.com/yjhua/p/525 ...

  7. springMVC接收get请求传递多个参数

    @RequestMapping(value = "/sendSignal/{state}/{limberId}/{account}", method = RequestMethod ...

  8. Windows Socket五种I/O模型——代码全攻略(转)

    Winsock 的I/O操作: 1. 两种I/O模式 阻塞模式:执行I/O操作完成前会一直进行等待,不会将控制权交给程序.套接字 默认为阻塞模式.可以通过多线程技术进行处理. 非阻塞模式:执行I/O操 ...

  9. RabbitMQ系列(一)--消息中间件MQ如何去选择

    MQ在项目中的应用很普遍,本人所在项目组使用的是ActiveMQ,但是后面介绍的RabbitMQ... 一.应用场景 1.异步处理 2.流量削峰.秒杀 3.日志处理,推荐kafka 4.应用解耦 二. ...

  10. 母牛的故事(hdoj 2018,动态规划递推,详解)

    有一头母牛,它每年年初生一头小母牛.每头小母牛从第四个年头开始,每年年初也生一头小母牛.请编程实现在第n年的时候,共有多少头母牛? Sample Input2450Sample Output246 / ...