黑马程序员技术交流社区

标题: 【上海校区】ListIterator和Iterator详解与辨析 [打印本页]

作者: yuchengmin    时间: 2018-8-15 22:03
标题: 【上海校区】ListIterator和Iterator详解与辨析
ListIterator和Iterator详解与辨析
在使用java集合的时候,都需要使用Iterator。但是java集合中还有一个迭代器ListIterator,在使用ListArrayListLinkedListVector的时候可以使用。这两种迭代器有什么区别呢?        下面我们详细分析。这里有一点需要明确的时候,迭代器指向的位置是元素之前的位置,如下图所示:
   
    这里假设集合List由四个元素List1List2List3List4组成,当使用语句Iterator it = List.Iterator()时,迭代器it指向的位置是上图中Iterator1指向的位置,当执行语句it.next()之后,迭代器指向的位置后移到上图Iterator2所指向的位置。
首先看一下IteratorListIterator迭代器的方法有哪些。
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
一、相同点
都是迭代器,当需要对集合中元素进行遍历不需要干涉其遍历过程时,这两种迭代器都可以使用。
二、不同点
1.使用范围不同,Iterator可以应用于所有的集合,SetListMap和这些集合的子类型。而ListIterator只能用于List及其子类型。
2.ListIteratoradd方法,可以向List中添加对象,而Iterator不能。
3.ListIteratorIterator都有hasNext()next()方法,可以实现顺序向后遍历,但是ListIteratorhasPrevious()previous()方法,可以实现逆向(顺序向前)遍历。Iterator不可以。
4.ListIterator可以定位当前索引的位置,nextIndex()previousIndex()可以实现。Iterator没有此功能。
5.都可实现删除操作,但是ListIterator可以实现对象的修改,set()方法可以实现。Iterator仅能遍历,不能修改。
IteratorListIterator用法示例

[Java] 纯文本查看 复制代码
 1package com.collection;
2import java.util.LinkedList;
3import java.util.List;
4import java.util.ListIterator;
5/**
6 * @author 朱伟
7 * 链表中ListIterator测试
8 */
9public class ListIteratorTest {
10        public static void main(String[] args) {
11                // TODO Auto-generated method stub
12                List<String> staff = new LinkedList<>();
13                staff.add("zhuwei");
14                staff.add("xuezhangbin");
15                staff.add("taozhiwei");
16                ListIterator<String> iter = staff.listIterator();
17                String first = iter.next();
18                //删除zhuwei
19                iter.remove();
20                //把zhuwei改为simei
21                //iter.set("simei");
22                System.out.println("first:"+first);
23                iter.add("xiaobai");
24                //遍历List元素
25                System.out.println("遍历List中元素,方法一:");
26                for(String str : staff)
27                        System.out.println(str+"   ");
28                iter = staff.listIterator();
29                System.out.println("遍历List中元素,方法二:");
30                while(iter.hasNext())
31                {
32                        System.out.println(iter.next());
33                }
34        }
35}


作者: 不二晨    时间: 2018-8-16 16:53
奈斯




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2