在使用for循环判断删除元素,遇到了一些坑,为了突出效果特意将for循环与迭代进行比较。
代码如下:
List<String> list = new ArrayList<>(); list.add("a"); list.add("a"); list.add("b"); list.add("n");
for (int i = 0; i < list.size(); i++) {
if("a".equals(list.get(i))){
list.remove(i);
}
}
List<String> list2 = new ArrayList<>();
list2.add("a");
list2.add("a");
list2.add("b");
list2.add("n");
Iterator<String> iterator = list2.iterator();
while(iterator.hasNext()){
if("a".equals(iterator.next())){
iterator.remove();
}
}
System.out.println("使用for循环删除后的结果:"+list);
System.out.println("使用迭代删除后的结果:"+list2);
输出结果如下:
使用for循环删除后的结果:[a, b, n]
使用迭代删除后的结果:[b, n]
出现这种情况的原因
因为for循环删除,每删除一个元素,索引就会发生改变,如果两个符合条件的元素靠近一起的话。
就会导致只会删除一个元素的情况出现,因此,删除集合元素时建议使用迭代器删除