参考文章:
http://blog.csdn.net/ws992077171/article/details/7856433
先看下面代码,大家猜猜打印的结果是什么?为什么?
package shiyan;
import java.util.ArrayList;
import java.util.List;
public class ListTest {
public static void main(String[] args) {
// TODO Auto-generated method stub
List<A> list = new ArrayList<A>();
A a1 = newA(1,"a1");
A a2 = newA(2,"a2");
A a3 = newA(3,"a3");
A a4 = newA(4,"a4");
A a5 = newA(5,"a5");
list.add(a1);
list.add(a2);
list.add(a3);
list.add(a4);
list.add(a5);
list.remove(a2);
System.out.println(list.size());
}
}
class A{
int id;
String name;
public A(int id,String name){
this.id = id;
this.name = name;
}
public boolean equals(Object obj) {
return false;
}
}
如果您的回答是:4,我想您就有必要看看本文了,因为正确答案是5
先贴上:ArrayList上的remove源码:
public boolean remove(Object o) {
if(o == null) {
for(int index = 0; index < size; index++)
if(elementData[index] == null) {
fastRemove(index);
return true;
}
}else{
for(int index = 0; index < size; index++)
if(o.equals(elementData[index])) {
fastRemove(index);
return true;
}
}
return false;
}
看源码可知,List在删除对象时,先判断这个对象是否在自己的队列中?而这种判断指的是是否equals
因此,List在删除对象时,如果使用删除对象方法,应该最好重写equals方法,否则最好使用删除下标的方法。
注:删除下标时一定要确保下标的类型是int类型,若是Integer类型,List会默认匹配remove(Object o)方法,而不是remove(int index)方法。