contains(Object o) 如果列表包含指定的元素,则返回 true
这里他的基本用法我们不再演示
我们来研究一下他的底层代码:
public boolean contains(Object o) {
return indexOf(o) >= 0;
}
//再进入indexOf方法-------------------------------------------------------------
public int indexOf(Object o) {
if (o == null) {
for (int i = 0; i < size; i++)
if (elementData[i]==null)
return i;
} else {
for (int i = 0; i < size; i++)
if (o.equals(elementData[i]))//注意:这里的o是你要判断是否存在的对象
//核心就是这里的equals方法
return i;
}
return -1;
}
//进入Object里的equals方法----------------------------------------------------------------
public boolean equals(Object obj) {
return (this == obj);//很明显这里比较的是地址
}
这是equals后面的elementData
这个数组本来是个空数组,通过add方法往里添加变量
接下来我们来看例子:
public class Student{
private String id;
public Student(String id){
this.id = id;
}
//重写Object中的equals方法
public boolean equals(Object obj){
//这里obj是数组中存储的对象,但是是Object类型的
Student stu = (Student)obj;
//obj无法调用子类新增的方法,所以我们将它下转型
return this.id.equals(stu.id);
//这里的this指的是调用这个equals方法的对象,即上面indexOf方法中的o,即contains()括号中的对象
}
public static void main(String[] args){
ArrayList<Student> list = new ArrayList<>();
list.add(new Student("111"));
System.out.println(list.contains(new Student("111")));
//如果我们不重写equals方法,这里输出的是false,因为他们使用==比较的是地址,如果我们从实际出发,现实生活中是没有两个人拥有同样的身份证号的,所以我们上面重写了Object里的equals方法,equals方法重写后,这里输出的就是true了
}
}
如果ArrayList中的泛型是Object类那么我们就要对equals做约束,否则有的类无法被成功下转型
public class Test{
public boolean equals(Object obj){
Student stu = (Student)obj;
return this.id.equals(stu.id);
}
public static void main(String[] args){
ArrayList<Object> list = new ArrayList<>();
list.add(new Date());
list.add(new Student("110");
System.out.println(list.contains(new Student("110")));
//这里就会报错,因为遍历比较时,Date类无法下转型为Student类,这时只要我们对equals方法稍微加一个条件判断即可
// public boolean equals(Object obj){
// if(obj instanceof Student){
// Student stu = (Student)obj;
// return this.id.equals(stu);
// }
// return false;
// }
}
}