JAVA中ListIterator和Iterator详解与辨析


原文链接:http://blog.csdn.net/longshengguoji/article/details/41551491


     在使用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所需位置后面元素的索引

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

       previousIndex():返回列表中ListIterator所需位置前面元素的索引

       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用法:

[java]  view plain  copy
  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. }  

猜你喜欢

转载自blog.csdn.net/guo_guo_cai/article/details/78542716
今日推荐