java——ArrayList中contains()方法中的疑问

问题引子:

ist<Student> students=new ArrayList<Student>();
students.add(new Student("20160800612"));
System.out.println(students.contains(new Student("20160800612")))

返回FALSE

Student stu=new Student("123");
students.add(stu);
System.out.println(students.contains(stu));

返回TRUE

对于以上代码,相信很多人有问题,这种不能靠主管想象力的,,,,我们还是来看后台代码靠谱

按住ctrl键点击contains进入List.class是一个接口,其中有的一个抽象方法 boolean contains(Object o);

他实际上调用的contains方法是ArrayList类中重新的contains方法

public boolean contains(Object o) {
return indexOf(o) >= 0;
}

按住ctrl键点击indexOf进入ArrayList类中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]))
return i;
}
return -1;
}

我们看到Object o会调用equals方法,但是Student中并没有重新equals方法,所以最后调用的事Object 中的equals方法

public boolean equals(Object obj) {
return (this == obj);
}

很明显,this==obj比较的事地址,所以两个new的对象地址肯定不是一样的,所以返回false

懂了吧~~~~~~~~~~~~~

所以还是多分析分析后台代码,更加清楚明白啦

怎么解决这个问题呢,就是在Student类中重写这个 equals方法,比较的时候去比较id  但是注意重写时参数是Object  我们需要下转型,这个时候要判断Object是否为Student

@Override
public boolean equals(Object obj) {
if(obj instanceof Student) 
return ((Student)obj).id.equals(this.id);
return false;
}

OK!!!!!!

原文地址:https://www.cnblogs.com/lyxcode/p/9453213.html