假设现在一个list里的元素为:[1,2,3,3,4]
1、通过普通for循环来删除元素
for(int i=0;i<list.size();i++){
if(list.get(i)==3) list.remove(i);
}
System.out.println(list);
打印:1,2,3,4
原因:当删除第一个3时,3后面元素都会向左移动,而当前index等于2,后一个3会移除到index=2的位置,因此会被跳过;如果不存在相邻元素,那么就不会出现这种情况
还有另一种解决方式,在找到对应元素时,index对应--
for(int i=0;i<list.size();i++){
if(list.get(i)==3) list.remove(i--);
}
System.out.println(list);
打印1,2,4
倒序遍历也正确,向左移动并不影响右边的元素
for(int i=list.size()-1;i>=0;i--){
if(list.get(i)==3){
list.remove(i);
}
}
System.out.println(list);
使用foreach遍历list删除元素
for(Integer i:list){
if(i==3) list.remove(i);
}
System.out.println(list);
这里会直接报异常
通过阅读源码得知,foreach的本质是迭代器的遍历,遍历过程中会调用一个next()方法,如果进行了add/remove,那么当前的修改次数不等于预期的修改次数,将会导致报错,因为迭代器不允许一个元素不知不觉被添加/删除
但如果你remove/add之后就退出while循环,那么就不会报错,或者说没有下一个元素了
list删除元素时,注意int和integer的区别
list.remove(2)会直接删除index=2的元素
list.remove(new Integer(2)),则删除元素值=2的值
remove元素的正确做法:通过Iterator接口
Iterator<Integer> it=list.iterator();
while(it.hasNext()){
if(it.next()==3){
it.remove();
}
}
System.out.println(list);