zoukankan      html  css  js  c++  java
  • JAVA中ListIterator和Iterator详解与辨析

    在使用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指向位置后面的元素

    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<String> staff = new LinkedList<>();  
    17             staff.add("zhuwei");  
    18             staff.add("xuezhangbin");  
    19             staff.add("taozhiwei");  
    20             ListIterator<String> 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     }  

     主要内容转自:http://blog.csdn.net/longshengguoji/article/details/41551491

  • 相关阅读:
    [System.currentTimeMillis]/[Calendar.getInstance().getTimeInMillis()]/[new Date().getTime()]
    [Maven]告警[WARNING] Unable to create Maven project from repository.
    通过设置JDK解决存在多个Gradle后台进程的问题
    使用OpenSSL实现X25519秘钥协商功能
    C++代码质量度量工具大阅兵
    Java代码质量度量工具大阅兵
    计算两个时间的时间差(天、小时、分钟、秒数)
    上传文件进度条 (已上传大小、总大小、速度、剩余时间、已用时间)
    table 表格自适应
    谷歌浏览器input框添加了黄色 背景色
  • 原文地址:https://www.cnblogs.com/MyBlog-Richard/p/5547563.html
Copyright © 2011-2022 走看看