1、ListIterator 继承 Iterator
2、ListIterator 比 Iterator多方法
-
add(E e) 将指定的元素插入列表,插入位置为迭代器当前位置之前
-
set(E e) 迭代器返回的最后一个元素替换参数e
-
hasPrevious() 迭代器当前位置,反向遍历集合是否含有元素
-
previous() 迭代器当前位置,反向遍历集合,下一个元素
-
previousIndex() 迭代器当前位置,反向遍历集合,返回下一个元素的下标
-
nextIndex() 迭代器当前位置,返回下一个元素的下标
3、使用范围不同,Iterator可以迭代所有集合;ListIterator 只能用于List及其子类
-
ListIterator 有 add 方法,可以向 List 中添加对象;Iterator 不能
-
ListIterator 有 hasPrevious() 和 previous() 方法,可以实现逆向遍历;Iterator不可以
-
ListIterator 有 nextIndex() 和previousIndex() 方法,可定位当前索引的位置;Iterator不可以
-
ListIterator 有 set()方法,可以实现对 List 的修改;Iterator 仅能遍历,不能修改。
四、怎么确保一个集合不能被修改?
我们很容易想到用final关键字进行修饰,我们都知道
final关键字可以修饰类,方法,成员变量,final修饰的类不能被继承,final修饰的方法不能被重写,final修饰的成员变量必须初始化值,如果这个成员变量是基本数据类型,表示这个变量的值是不可改变的,如果说这个成员变量是引用类型,则表示这个引用的地址值是不能改变的,但是这个引用所指向的对象里面的内容还是可以改变的
。
那么,我们怎么确保一个集合不能被修改?首先我们要清楚,集合(map,set,list…)都是引用类型,所以我们如果用final修饰的话,集合里面的内容还是可以修改的。
我们可以做一个实验:
可以看到:我们用final关键字定义了一个map