ArrayList<String> list = new ArrayList(); list.add("111"); list.add("222"); list.add("333"); Iterator var7 = list.iterator();
while(var7.hasNext()) { String i = (String)var7.next(); System.out.println(i); }
可见,遍历数组使用的是原始 for 循环,集合的话使用的是 Iterator迭代器。
删除元素
使用 for 循环:
1 2 3 4 5 6 7 8 9 10
ArrayList<String> list = new ArrayList<>(); list.add("111"); list.add("222"); list.add("333"); log.info(list.toString()); for (int i = 0; i <list.size(); i++) { list.remove("222"); }
ArrayList<String> list = new ArrayList<>(); list.add("111"); list.add("222"); list.add("333"); log.info(list.toString()); for (String i : list) { list.remove("222"); } log.info(list.toString());
结果:
1 2 3 4 5
11:50:48.333 [main] INFO com.xiaolinge.com.hello.HelloWord - [111, 222, 333] Exception in thread "main" java.util.ConcurrentModificationException at java.util.ArrayList$Itr.checkForComodification(ArrayList.java:909) at java.util.ArrayList$Itr.next(ArrayList.java:859) at com.xiaolinge.com.hello.HelloWord.main(HelloWord.java:30)
显然木有成功!
原因:
迭代器内部的每次遍历都会记录 List 内部的 modcount 当做预期值,然后在每次循环中用预期值与 List 的成员变量 modCount 作比较,但是普通list.remove 调用的是 List 的 remove ,这时 modcount++ ,但是 iterator 内记录的预期值 = 并没有变化,所以会报错。
如果想要删除元素的话需要使用迭代器内部的 remove 方法:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
ArrayList<String> list = new ArrayList<>(); list.add("111"); list.add("222"); list.add("333"); log.info(list.toString()); Iterator<String> it = list.iterator(); while (it.hasNext()){ String next = it.next(); //if外使用list的remove方法还是会报错的 if(next.equals("222")){ it.remove();//这里使用的是迭代器里面的remove()方法, // 当然如果使用list的remove方法在此删除质地感元素的话是成功的,比如:list.remove("222") } } log.info(list.toString());
ArrayList<String> list = new ArrayList<>(); list.add("111"); list.add("222"); list.add("333"); log.info(list.toString()); for (int i = 0; i <list.size(); i++) { list.set(i,"444"); } log.info(list.toString());
ArrayList<String> list = new ArrayList<>(); list.add("111"); list.add("222"); list.add("333"); log.info(list.toString()); for (String i : list) { i="444"; } log.info(list.toString());