概述:
在使用java集合的时候,大家都知道都需要使用Iterator,但是java集合中还有一个迭代器ListIterator,在使用List、ArrayList、LinkedList和Vector的时候可以使用。这两种迭代器有什么区别呢?
下面我们详细分析。这里有一点需要明确的时候,迭代器指向的位置是元素之前的位置,如下图所示:
这里假设集合List由四个元素List1、List2、List3和List4组成,当使用语句Iterator it = List.Iterator()时,迭代器it指向的位置是上图中Iterator1指向的位置,当执行语句it.next()之后,迭代器指向的位置后移到上图Iterator2所指向的位置。
包含的方法:
说明:首先看一下Iterator和ListIterator迭代器的方法有哪些。
Iterator迭代器包含的方法有:
- hasNext():如果迭代器指向位置后面还有元素,则返回 true,否则返回false
- next():返回集合中Iterator指向位置后面的元素
- remove():删除集合中Iterator指向位置后面的元素
public class iteratorTest {
public static void main(String[] args) {
ArrayList list = new ArrayList();
list.add("hhh");
list.add("aaa");
list.add("ccc");
Iterator it = list.Iterator();
while(it.hasNext()){//判断,有元素的话返回true,没有元素返回false
Object value = it.next();//获取Iterator当前位置后面的元素
System.out.println(value);
}
}
打印结果:
hhh
aaa
ccc
ListIterator迭代器包含的方法有:
- add(E e): 将指定的元素插入列表,插入位置为迭代器当前位置之前
- hasNext():以正向遍历列表时,如果列表迭代器后面还有元素,则返回 true,否则返回false
- hasPrevious() : 如果以逆向遍历列表,列表迭代器前面还有元素,则返回 true,否则返回false
- next():返回列表中ListIterator指向位置后面的元素
- nextIndex() :返回列表中ListIterator所需位置后面元素的索引
- previous() : 返回列表中ListIterator指向位置前面的元素
- previousIndex():返回列表中ListIterator所需位置前面元素的索引
- set(E e):从列表中将next()或previous()返回的最后一个元素返回的最后一个元素更改为指定元素e
相同点:
都是迭代器,当需要对集合中元素进行遍历不需要干涉其遍历过程时,这两种迭代器都可以使用。
不同点:
1).使用范围不同,Iterator可以应用于所有的集合,Set、List和Map和这些集合的子类型。而ListIterator只能用于List及其子类型。
2).ListIterator有add方法,可以向List中添加对象,而Iterator不能。
3).istIterator和Iterator都有hasNext()和next()方法,可以实现顺序向后遍历,但是ListIterator有hasPrevious()和previous()方法,可以实现逆向(顺序向前)遍历。Iterator不可以。
4).ListIterator可以定位当前索引的位置,nextIndex()和previousIndex()可以实现。Iterator没有此功能。
5).都可实现删除操作,但是ListIterator可以实现对象的修改,set()方法可以实现。Iterator仅能遍历,不能修改。
案例:
public class iteratorTest {
/**
* @ClassName: IteratorTest1
* @Description: 反向遍历list集合
*/
public static void main(String[] args) {
List<Integer> list = new ArrayList<Integer>();
for(int i=0;i<10;i++){
list.add(i);
}
//1.正向遍历
//1.1获取迭代器
ListIterator<Integer> lt = list.listIterator();
System.out.println("list集合正向遍历:");
while(lt.hasNext()){//1.2判断当前指向的位置后有没有元素
Integer n= lt.next();//1.3如果有获取当前指向位置的元素
System.out.print(n);
}
System.out.println("");
System.out.println("list集合反向遍历:");
//2.反向遍历
//2.1 将游标定位到集合的结尾
while(lt.hasNext()){
lt.next();
}
//使用反向遍历的方法
while(lt.hasPrevious()){//2.2这时游标已定位到集合结尾处,判断游标位置前面是否有元素
Integer m=lt.previous();//2.3如果有元素,就获取到前面的元素
System.out.print(m);
}
}
输出结果:
list集合正向遍历:
0123456789
list集合反向遍历:
9876543210
谢谢您的阅读,希望对您有所帮助!