先上代码:
public static void main(String[] args) {
Integer[] arr = new Integer[] { 1, 2, 3, 4, 5, 4, 3, 2, 1 };
List<Integer> list = new ArrayList<Integer>(Arrays.asList(arr));
for (int i = 0; i < list.size(); i++) {
if (list.get(i) > 2) {
list.remove(i);
// 屏蔽i--以演示错误的处理方式
// i--;
}
System.out.println(i);
}
System.out.println("-----------------");
printList(list);
}
public static void printList(List<Integer> list) {
for (Integer obj : list) {
System.out.println(obj);
}
}
执行结果如下:
0
1
2
3
4
5
-----------------
1
2
4
4
2
1
可以看到只执行了6次,结果也不对,为什么呢?咱把执行过程画出来
如图所示,从i=2时开始list[2]=3,删除list[2]元素后,后面所有的元素都要向前移动一位。第一个数值为4的元素跑到了前面变成了list[2]=4,但2号(从0开始计数)元素已经遍历过,下次遍历从3号开始,于是产生第一个错误数据list[2]=4,后面的同理。
那么怎么解决呢?
1、每次删除数据引起元素向前yiwe移位时,手动调整当前遍历的下标,重新遍历当前位置,比如index = index - 1;
2、倒序遍历,即for (int i = list.size() - 1; i >= 0 ;i --)这样每次删除的是已经遍历过的元素且不会影响未遍历元素的位置;
3、使用迭代器Iterator