ListIterator和Iterator區(qū)別

在使用java集合的時候,都需要使用Iterator。但是java集合中還有一個迭代器ListIterator,在使用List、ArrayList、LinkedList和Vector的時候可以使用。這兩種迭代器有什么區(qū)別呢?下面我們詳細分析。這里有一點需要明確的時候,迭代器指向的位置是元素之前的位置,如下圖所示:


這里假設(shè)集合List由四個元素List1、List2、List3和List4組成,當使用語句Iterator it = List.Iterator()時,迭代器it指向的位置是上圖中Iterator1指向的位置,當執(zhí)行語句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可以應(yīng)用于所有的集合,Set、List和Map和這些集合的子類型。而ListIterator只能用于List及其子類型。
  • 2.ListIterator有add方法,可以向List中添加對象,而Iterator不能。
  • 3.ListIterator和Iterator都有hasNext()和next()方法,可以實現(xiàn)順序向后遍歷,但是ListIterator有hasPrevious()和previous()方法,可以實現(xiàn)逆向(順序向前)遍歷。Iterator不可以。
  • 4.ListIterator可以定位當前索引的位置,nextIndex()和previousIndex()可以實現(xiàn)。Iterator沒有此功能。
  • 5.都可實現(xiàn)刪除操作,但是ListIterator可以實現(xiàn)對象的修改,set()方法可以實現(xiàn)。Iterator僅能遍歷,不能修改。

三:Iterator和ListIterator用法示例

ListIterator用法:

package com.collection;  
  
import java.util.LinkedList;  
import java.util.List;  
import java.util.ListIterator;  
  
/** 
 * @author 朱偉 
 * 鏈表中ListIterator測試 
 * 
 */  
public class ListIteratorTest {  
  
    public static void main(String[] args) {  
        // TODO Auto-generated method stub  
        List<String> staff = new LinkedList<>();  
        staff.add("zhuwei");  
        staff.add("xuezhangbin");  
        staff.add("taozhiwei");  
        ListIterator<String> iter = staff.listIterator();  
        String first = iter.next();  
          
        //刪除zhuwei  
        iter.remove();  
          
        //把zhuwei改為simei  
        //iter.set("simei");  
        System.out.println("first:"+first);  
          
        iter.add("xiaobai");  
          
        //遍歷List元素  
        System.out.println("遍歷List中元素,方法一:");  
        for(String str : staff)  
            System.out.println(str+"   ");  
          
        iter = staff.listIterator();  
        System.out.println("遍歷List中元素,方法二:");  
        while(iter.hasNext())  
        {  
            System.out.println(iter.next());  
        }  
    }  
}  
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容