出于兴趣再看Iterator,突然发现一个更强大的ListIterator
Iterator
ArrayList<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("c");
Iterator<String> it =list.iterator();
System.out.println(it);
while(it.hasNext()){
String str = it.next();
System.out.println(str);
// list.add("d"); //报错集合遍历时进行删除或者新增操作,都会抛出 ConcurrentModificationException 异常
list.set(0, "e"); //修改操作不会造成异常
it.remove(); //迭代器的删除不会报错
}
System.out.println(list.size()); //0
迭代器 ListIterator
ArrayList<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("c");
ListIterator<String> listIt = list.listIterator();
// 向后遍历
while (listIt.hasNext()) {
System.out.print(listIt.next() + " ");// a b c
listIt.add("1");// 在每一个元素后面增加一个元素 "1"
}
// 向后前遍历,此时由于上面进行了向后遍历,游标已经指向了最后一个元素,所以此处向前遍历能有值
while (listIt.hasPrevious()) {
System.out.print(listIt.previous() + " ");// 1 c 1 b 1 a
}
#也就是说相比于 Iterator 迭代器,这里的 ListIterator 多出了能向前迭代,以及能够新增元素