JAVA中ListIterator和Iterator详解与辨析
发布日期:2022-02-22 18:04:12 浏览次数:12 分类:技术文章

本文共 3057 字,大约阅读时间需要 10 分钟。

在使用集 合的时候,都需要使用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指向位置后面的元素

ListIterator迭代器包含的方法有:

   add(E e): 将指定的元素插入列表,插入位置为迭代器当前位置之前

hasNext():以正向遍历列表时,如果列表迭代器后面还有元素,则返回 true,否则返回false

hasPrevious():如果以逆向遍历列表,列表迭代器前面还有元素,则返回 true,否则返回false

next():返回列表中ListIterator指向位置后面的元素,并且迭代器位置后移一位,

nextIndex():返回列表中ListIterator所位置后面元素的索引,ps:即便迭代器后边没有元素了,也返回假设后面还有元素,则该元素的应有的序号

previous():返回列表中ListIterator指向位置前面的元素

previousIndex():返回列表中ListIterator所位置前面元素的索引,ps:即便迭代器前边边没有元素了,也返回假设前面还有元素,则该元素的应有的序号

remove():从列表中删除next()或previous()返回的最后一个元素(有点拗口,意思就是对迭代器使用hasNext()方法 时,删除ListIterator指向位置后面的元素;当对迭代器使用hasPrevious()方法时,删除ListIterator指向位置前面的元 素)

set(E e):从列表中将next()或previous()返回的最后一个元素返回的最后一个元素更改为指定元素e

一.相同点

都是迭代器,当需要对集合中元素进行遍历不需要干涉其遍历过程时,这两种迭代器都可以使用。

二.不同点

1.使用范围不同,Iterator可以应用于所有的集合,Set、List和Map和这些集合的子类型。而ListIterator只能用于List及其子类型。

2.ListIterator有add方法,可以向List中添加对象,而Iterator不能。

3.ListIterator和Iterator都有hasNext()和next()方法,可以实现顺序向后遍历,但是ListIterator有hasPrevious()和previous()方法,可以实现逆向(顺序向前)遍历。Iterator不可以。

4.ListIterator可以定位当前索引的位置,nextIndex()和previousIndex()可以实现。Iterator没有此功能。

5.都可实现删除操作,但是ListIterator可以实现对象的修改,set()方法可以实现。Iterator仅能遍历,不能修改。

三:Iterator和ListIterator用法示例

ListIterator用法:

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

 主要内容转自:

转载于:https://www.cnblogs.com/MyBlog-Richard/p/5547563.html

转载地址:https://blog.csdn.net/dengsigukan55762/article/details/101976091 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:C++构造函数
下一篇:C++类成员在内存中的存储及对齐方式

发表评论

最新留言

网站不错 人气很旺了 加油
[***.192.178.218]2024年04月12日 06时34分11秒