Java中Iterator(迭代器)和listIterator的用法

Iterator

1.概念

   **迭代器是一种设计模式,它是一个对象,它可以遍历并选择序列中的对象,而开发人员不需要了解该序列的底层结构。迭代器通常被称为“轻量级”对象,因为创建它的代价小。**
   客户端从不直接和集合类打交道,它总是控制 Iterator,向它发送”向前”,”向后”,”取当前元素”的命令,就可以间接遍历整个集合。
  所有实现了Collection接口的容器类都有一个iterator方法用以返回一个实现了Iterator接口的对象。

2.方法

   (1)boolean hasNext():判断是否存在另一个可访问的元素。
   (2)Object next():返回要访问的下一个元素。
   (3)void remove():删除上次访问返回的对象。

3.ArrayList的Iterator实现

private class Itr implements Iterator<E> {
    int cursor;//表示下一个元素的索引位置       
    int lastRet = -1;//表示上一个元素的索引位置 
    int expectedModCount = modCount;

    Itr() {}

    //从 cursor、lastRet 定义可以看出,lastRet 一直比 cursor 少一所以
    // hasNext() 实现方法异常简单,只需要判断 cursor 和 lastRet 是否相等即可。
    public boolean hasNext() {
        return cursor != size;
    }

    //对于 next() 实现其实也是比较简单的,只要返回 cursor 索引位置处的元素即可,
    //然后修改 cursor、lastRet 即可.
    @SuppressWarnings("unchecked")
    public E next() {
        checkForComodification();
        /*checkForComodification() 主要用来判断集合的修改次数是否合法,即用来判断遍历过程中
        /*集合是否被修改过。modCount 用于记录 ArrayList 集合的修改次数,初始化为 0,每当集合被
        /*修改一次(结构上面的修改,内部update不算),如 add、remove 等方法,modCount + 1,所以
        /*如果 modCount 不变,则表示集合内容没有被修改。*/
        int i = cursor;//记录索引位置
        if (i >= size) //如果获取元素大于集合元素个数,则抛出异常。
            throw new NoSuchElementException();
        Object[] elementData = ArrayList.this.elementData;
        if (i >= elementData.length)
            throw new ConcurrentModificationException();
        cursor = i + 1;
        return (E) elementData[lastRet = i];
    }

    //对于 remove() 方法的是实现,它是调用 ArrayList 本身的 remove() 方法删除 lastRet 位置元素,然后修改 modCount 即可。
    public void remove() {
        if (lastRet < 0)
            throw new IllegalStateException();
        checkForComodification();

        try {
            ArrayList.this.remove(lastRet);
            cursor = lastRet;
            lastRet = -1;
            expectedModCount = modCount;
        } catch (IndexOutOfBoundsException ex) {
            throw new ConcurrentModificationException();
        }
    }

4.应用举例

import java.util.ArrayList;
import java.util.ListIterator;

public class IteratorDemo {
    public static void main(String[] args) {
        ArrayList list = new ArrayList();
        //使用add()将指定对象存储到容器中
        list.add(1);
        list.add(2);
        list.add(3);
        Iterator it = list.Iterator();
        while(it.hasNext()){
            Integer itr = (Integer) it.next();
            System.out.println(itr);
        }
    }
}

输出结果为:
1
2
3
可以看到,Iterator可以不用管底层数据具体是怎样存储的,都能够通过next()遍历整个List。

ListIterator

1.作用

解决并发操作异常。
在迭代时,丌可能通过集合对象的方法(al.add(?))操作集合中的元素,会发生并发修改异常。所以,在迭代时只能通过迭代器的方法操作元素,但是Iterator的方法是有限的,只能进行判断(hasNext),取出(next),删除(remove)的操作,如果想要在迭代的过程中进行向集合中添加,修改元素等就需要使用ListIterator接口中的方法。

2.方法

(1)add(E e): 将指定的元素插入列表,插入位置为迭代器当前位置之前
(2)boolean hasNext():以正向遍历列表时,如果列表迭代器后面还有元素,则返回 true,否则返回false
(3)boolean hasPrevious():如果以逆向遍历列表,列表迭代器前面还有元素,则返回 true,否则返回false
(4)int next():返回列表中ListIterator指向位置后面的元素
(5)int nextIndex():返回列表中ListIterator所需位置后面元素的索引
(6)previous():返回列表中ListIterator指向位置前面的元素
(7)previousIndex():返回列表中ListIterator所需位置前面元素的索引
(8)remove():从列表中删除next()或previous()返回的最后一个元素(有点拗口,意思就是对迭代器使用hasNext()方法时,删除ListIterator指向位置后面的元素;当对迭代器使用hasPrevious()方法时,删除ListIterator指向位置前面的元素)
(9)set(E e):从列表中将next()或previous()返回的最后一个元素返回的最后一个元素更改为指定元素e

3.应用举例

import java.util.ArrayList;
import java.util.ListIterator;

public class IteratorDemo {
    public static void main(String[] args) {
        ArrayList list = new ArrayList();
        //使用add()将指定对象存储到容器中
        list.add("好");
        list.add("好");
        list.add("学");
        list.add("习");
        list.add("java");
        ListIterator<String> li = list.listIterator();
        while(li.hasNext()){
            String next = (String) li.next();

            if(next.equals("java")){
                //删除ListIterator指向位置后面的元素
                li.remove();
                //添加元素
                li.add("天天向上");
            }
            //输出遍历的元素
            System.out.println(next);
        }
        System.out.println(list);
    }
}

输出结果为:




java
[好, 好, 学, 习, 天天向上]

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值