Iterator和ListIterator两种迭代器的简介和区别

Iterator:

可用于所有Collection.

方法:

  • hasNext():如果仍有元素可以迭代,则返回 true.
  • next():返回迭代的下一个元素 ,可以重复调用此方法来迭代此列表.
  • remove():从迭代器指向的 collection 中移除迭代器返回的最后一个元素。每次调用 next 只能调用一次此方法.

 

while:

Iterator<Integer> it = list.iterator();
while(it.hasNext()) {
    it.next();                    //跳一位遍历
    System.out.print(it.next());
    it.remove();
}

 for:

for(Iterator<Integer> it = list.iterator(); it.hasNext();) {
    System.out.print(it.next());
    it.remove();
}

注:若用普通for循环遍历remove,会出现缺项问题.

 

ListIterator:

只能用于List及其子类,ArrayList,vector,LinkedList等.

ListIterator 没有当前元素;它的光标位置始终位于调用 previous() 所返回的元素和调用 next() 所返回的元素之间.

长度为 n 的列表的迭代器有 n+1 个可能的指针位置.

  • 可指定当前索引位置
ListIterator<Integer> it = list.listIterator(1);
while(it.hasNext()) {
    System.out.print(it.next());
}

 

ListIterator<Integer> it = list.listIterator(list.size());
while(it.hasPrevious()) {
    System.out.print(it.previous());
}

 

 

方法:

  • hasNext():以正向遍历列表时,如果列表迭代器有多个元素,则返回 true.
  • next():返回列表中的下一个元素。可以重复调用此方法来迭代此列表,或混合调用 previous 来前后移动.
  • nextIndex():返回对 next 的后续调用所返回元素的索引。(如果列表迭代器在列表的结尾,则返回列表的大小)
  • hasPrevious():如果以逆向遍历列表,列表迭代器有多个元素,则返回 true.
  • previous():返回列表中的前一个元素。可以重复调用此方法来迭代列表,或混合调用 next 来前后移动.
  • previousIndex():返回对 previous 的后续调用所返回元素的索引。(如果列表迭代器在列表的开始,则返回 -1)
  • add(e):将指定的元素插入列表。该元素直接插入到 next 返回的下一个元素的前面,或者 previous 返回的下一个元素之后.
  • remove():从列表中移除由 next 或 previous 返回的最后一个元素。对于每个 next 或 previous 调用,只能执行一次此调用。只有在最后一次调用 next 或 previous 之后,尚未调用 ListIterator.add 时才可以执行该调用.
  • set(e):用指定元素替换 next 或 previous 返回的最后一个元素。只有在最后一次调用 next 或 previous 后既没有调用 ListIterator.remove 也没有调用 ListIterator.add 时才可以进行该调用

 

两者的异同点:

相同:

  • 都是迭代器,当需要对集合中元素进行遍历不需要干涉其遍历过程时,这两种迭代器都可以使用
  • 都有hasNext()和next()方法,可以实现顺序向后遍历
  • 都可以remove()

 

不同:

  1. 使用范围不同,Iterator可以应用于所有的集合,而ListIterator只能用于List及其子类型
  2. ListIterator可以定位当前索引的位置,有nextIndex()和previousIndex(),而Iterator不可以
  3. ListIterator有hasPrevious()和previous()方法,可以实现向前遍历,而Iterator不可以
  4. ListIterator有add(e)方法,可以向List中添加对象,而Iterator不可以
  5. ListIterator有set(e)方法,可以对List中的对象进行修改,而Iterator不可以
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值