JAVA后端面试必知——ListIterator和Iterator的异同
在使用Java集合的时候,都需要使用Iterator。但是java集合中还有一个迭代器ListIterator,在使用List、ArrayList、LinkedList和Vector的时候可以使用。这两种迭代器有什么区别呢?下面我们详细分析。这里有一点需要明确的时候,迭代器指向的位置是元素之前的位置。
首先看一下Iterator和ListIterator迭代器的方法有哪些。
Iterator迭代器包含的方法有:
- hasNext():如果迭代器指向位置后面还有元素,则返回 true,否则返回false
- next():返回集合中Iterator指向位置后面的元素
- remove():删除集合中Iterator指向位置后面的元素
ListIterator迭代器包含的方法有:
- add(E e): 将指定的元素插入列表,插入位置为迭代器当前位置之前
- hasNext():以正向遍历列表时,如果列表迭代器后面还有元素,则返回 true,否则返回false
- hasPrevious():如果以逆向遍历列表,列表迭代器前面还有元素,则返回 true,否则返回false
- next():返回列表中ListIterator指向位置后面的元素
- nextIndex():返回列表中ListIterator所需位置后面元素的索引
- previous():返回列表中ListIterator指向位置前面的元素
- previousIndex():返回列表中ListIterator所需位置前面元素的索引
- remove():从列表中删除next()或previous()返回的最后一个元素(有点拗口,意思就是对迭代器使用hasNext()方法时,删除ListIterator指向位置后面的元素;当对迭代器使用hasPrevious()方法时,删除ListIterator指向位置前面的元素)
- set(E e):从列表中将next()或previous()返回的最后一个元素返回的最后一个元素更改为指定元素e
相同点
- 都是迭代器,当需要对集合中元素进行遍历不需要干涉其遍历过程时,这两种迭代器都可以使用。
不同点
使用范围不同,Iterator可以应用于所有的集合,Set、List和Map和这些集合的子类型。而ListIterator只能用于List及其子类型。
ListIterator有add方法,可以向List中添加对象,而Iterator不能。
ListIterator和Iterator都有hasNext()和next()方法,可以实现顺序向后遍历,但是ListIterator有hasPrevious()和previous()方法,可以实现逆向(顺序向前)遍历。Iterator不可以。
ListIterator可以定位当前索引的位置,nextIndex()和previousIndex()可以实现。Iterator没有此功能。
都可实现删除操作,但是ListIterator可以实现对象的修改,set()方法可以实现。Iterator仅能遍历,不能修改。
ArrayList<String> stringArrayList1 = new ArrayList<String>(); ArrayList<String> stringArrayList2 = new ArrayList<String>(); stringArrayList1.add("ok"); stringArrayList1.add("hello"); stringArrayList1.add("world"); stringArrayList2.add("好的"); stringArrayList2.add("你好"); stringArrayList2.add("世界"); stringArrayList1.addAll(stringArrayList2); ListIterator<String> iterator = stringArrayList1.listIterator(); System.out.println("从前往后输出:"); while (iterator.hasNext()){ System.out.println("next="+iterator.next()); } System.out.println("\r\n从后往前输出:"); while (iterator.hasPrevious()){ System.out.println("previous="+iterator.previous()); }
注意:一定要先进行由前向后输出,之后才能进行由后向前的输出。
写在最后
相关文章