简介
Iterator接口是对collection进行迭代的迭代器,ListIterator接口是其子接口。它们都是遍历集合的工具。
Collection依赖于Iterator,其实现类必须实现iterator()函数,返回一个Iterator对象.
ListIterator是专门遍历List而存在的。
Iterator
Iterator迭代器包含以下三种方法:
- boolean hasNext():如果仍有元素可迭代,返回true
- E next():返回迭代的下一个元素
- void remove():从迭代器指向的Collection中移动迭代器返回的最后一个元素,每次调用next只能调用一次此方法。
ListIterator
ListIterator迭代器包含以下九种方法:
- void add(E e):将指定的元素插入列表
- boolean hasNext():以正向遍历列表时,如果列表迭代器有多个元素,则返回true
- boolean hasPrevious():以逆向遍历列表时,如果列表迭代器有多个元素,则返回true
- E next():返回列表中的下一个元素
- int nextIndex():返回对next的后续调用所返回元素的指引
- E previous():返回列表的前一个元素
- int previousIndex():返回对previous的后续调用所返回元素的指引
- void remove():从列表中移除由next或previous返回的最后一个元素
- void set(E e):用指定元素替换next或previous返回的最后一个元素
Iterator和ListIterator异同点
相同:
都可以对集合中的元素进行遍历。
不同:
- 使用范围不同,Iterator可用于所有集合;而ListIterator只能用于List及其子类型,如List、ArrayList、LinkedList和Vector等。
- ListIterator可通过set()方法实现对象的修改,而Iterator不能
- ListIterator可用过nextIndex()或previousIndex()得到后续调用所返回元素的索引,而Iterator不能
- ListIterator可实现双向遍历,而Iterator只能顺序向前遍历
- ListIterator可通过add()添加对象,而Iterator不能