广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >如何使用迭代器
  • 437
分享到

如何使用迭代器

2024-04-02 19:04:59 437人浏览 八月长安
摘要

本篇内容介绍了“如何使用迭代器”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!阅读下面这段代码,请写出这段代

本篇内容介绍了“如何使用迭代器”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

阅读下面这段代码,请写出这段代码的输出内容:

import java.util.ArrayList; import java.util.Iterator; import java.util.*;  public class Test {     public static void main(String[] args) {          List<String> list = new ArrayList<>();         list.add("1");         list.add("2");         list.add("3");         Iterator iterator = list.iterator();         while (iterator.hasNext()) {             String str = (String) iterator.next();             if (str.equals("2")) {                 iterator.remove();             }         }         while (iterator.hasNext()) {             System.out.println(iterator.next());         }         System.out.println("4");     } }

他写出来的答案是:

1 3 4

奇怪的是,你把这道题目发给你身边人,让他们回答这道面试题输出结果是什么,说这个结果的人非常多。不行你试试。

答案明显不对,因为在第一个while里的  iterator.hasNext()==false后才会到第二个while里来,同一个Iterator对象,前面调一次iterator.hasNext()==false,再判断一次结果不还是一样吗?,

所以第二个while判断为false,也就不会再去遍历iterator了,由此可知本体答案是:4。

下面我们来分析一下为什么是具体底层是怎么实现的。

这里的Iterator是什么?

  • 迭代器是一种模式、详细可见其设计模式,可以使得序列类型的数据结构的遍历行为与被遍历的对象分离,即我们无需关心该序列的底层结构是什么样子的。只要拿到这个对象,使用迭代器就可以遍历这个对象的内部

  • Iterable 实现这个接口的集合对象支持迭代,是可以迭代的。实现了这个可以配合foreach使用~

  • Iterator 迭代器,提供迭代机制的对象,具体如何迭代是这个Iterator接口规范的。

Iterator说明

public interface Iterator<E> {      //每次next之前,先调用此方法探测是否迭代到终点     boolean hasNext();     //返回当前迭代元素 ,同时,迭代游标后移     E next();           default void remove() {         throw new UnsupportedOperationException("remove");     }      default void forEachRemaining(Consumer<? super E> action) {         Objects.requireNonNull(action);         while (hasNext())             action.accept(next());     } }

这里的实现类是ArrayList的内部类Itr。

private class Itr implements Iterator<E> {         int cursor;       // index of next element to return         int lastRet = -1; // index of last element returned; -1 if no such         //modCountshi ArrayList中的属性,当添加或删除的时候moCount值会增加或者减少         //这里主要是给fail-fast使用,避免一遍在遍历,一遍正在修改导致数据出错         //此列表在结构上被修改的次数。结构修改是指改变结构尺寸的修改列表,         //或者以这样的方式对其进行扰动,进步可能会产生错误的结果。         int expectedModCount = modCount;                  public boolean hasNext() {             //cursor初始值为0,没掉一次next方法就+1             //size是ArrayList的大小             return cursor != size;         }          @SuppressWarnings("unchecked")         public E next() {             checkForComodification();             int i = cursor;             if (i >= size)                 throw new NoSuchElementException();             //把ArrayList中的数组赋给elementData             Object[] elementData = ArrayList.this.elementData;             if (i >= elementData.length)                 throw new ConcurrentModificationException();             //每调用一次next方法,游标就加1             //cursor=lastRet+1             cursor = i + 1;             //返回ArrayList中的元素             return (E) elementData[lastRet = i];         }          public void remove() {             if (lastRet < 0)                 throw new IllegalStateException();             checkForComodification();              try {                 //调用ArrayList中remove方法,溢出该元素                 ArrayList.this.remove(lastRet);                 //cursor=lastRet+1,                 //所以此时相当于cursor=cursor-1                 cursor = lastRet;                 lastRet = -1;                 expectedModCount = modCount;             } catch (IndexOutOfBoundsException ex) {                 throw new ConcurrentModificationException();             }         }         final void checkForComodification() {             if (modCount != expectedModCount)                 throw new ConcurrentModificationException();         } }

再回到上面题目中:

第一个iterator.hasNext()

  • 第1次循环hasNext方法中:cursor==0, size==3,所以cursor !=  size返回true。

  • next方法中:cursor=0+1。返回"1"。

第2次循环

  • hasNext方法中:cursor==1, size==3,所以cursor != size返回true。

  • next方法中:cursor=1+1。返回"2"。

  • remove方法中:cursor==cursor-1==2-1=1,把ArrayList中的"2"给删除了,所以size==2。

第3次循环

  • hasNext方法中:cursor==1, size==2,那么cursor != size返回true。

  • next方法中:cursor=1+1==2;返回"3"。

第4次循环

  • hasNext方法中:cursor==2, size==2,那么cursor != size返回false。

第二个iterator.hasNext()

hasNext方法中:cursor==2, size==2,所以cursor !=  size返回false。

所以,最后只输出"4",即答案为4.

Iterator与泛型搭配

  • Iterator对集合类中的任何一个实现类,都可以返回这样一个Iterator对象。可以适用于任何一个类。

  • 因为集合类(List和Set等)可以装入的对象的类型是不确定的,从集合中取出时都是Object类型,用时都需要进行强制转化,这样会很麻烦,用上泛型,就是提前告诉集合确定要装入集合的类型,这样就可以直接使用而不用显示类型转换.非常方便.

foreach和Iterator的关系

  • for  each以用来处理集合中的每个元素而不用考虑集合定下标。就是为了让用Iterator简单。但是删除的时候,区别就是在remove,循环中调用集合remove会导致原集合变化导致错误,而应该用迭代器的remove方法。

使用for循环还是迭代器Iterator对比

  • 采用ArrayList对随机访问比较快,而for循环中的get()方法,采用的即是随机访问的方法,因此在ArrayList里,for循环较快

  • 采用LinkedList则是顺序访问比较快,iterator中的next()方法,采用的即是顺序访问的方法,因此在LinkedList里,使用iterator较快

  • 从数据结构角度分析,for循环适合访问顺序结构,可以根据下标快速获取指定元素.而Iterator  适合访问链式结构,因为迭代器是通过next()和Pre()来定位的.可以访问没有顺序的集合.

  • 而使用 Iterator 的好处在于可以使用相同方式去遍历集合中元素,而不用考虑集合类的内部实现(只要它实现了 java.lang.Iterable  接口),如果使用 Iterator 来遍历集合中元素,一旦不再使用 List 转而使用 Set 来组织数据,那遍历元素的代码不用做任何修改,如果使用 for  来遍历,那所有遍历此集合的算法都得做相应调整,因为List有序,Set无序,结构不同,他们的访问算法也不一样.(还是说明了一点遍历和集合本身分离了)。

总结

  • 迭代出来的元素都是原来集合元素的拷贝。

  • Java集合中保存的元素实质是对象的引用,而非对象本身。

  • 迭代出的对象也是引用的拷贝,结果还是引用。那么如果集合中保存的元素是可变类型的,那么可以通过迭代出的元素修改原集合中的对象。

“如何使用迭代器”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: 如何使用迭代器

本文链接: https://www.lsjlt.com/news/83902.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何使用迭代器
    本篇内容介绍了“如何使用迭代器”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!阅读下面这段代码,请写出这段代...
    99+
    2022-10-19
  • python如何使用迭代器
    小编给大家分享一下python如何使用迭代器,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!迭代器(切片)如果对返回一个对象进行简单的操作,会提示生成对象下的“Ty...
    99+
    2023-06-27
  • Python迭代器如何使用
    这篇文章主要讲解了“Python迭代器如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python迭代器如何使用”吧!Python 迭代器迭代器是一种对象,该对象包含值的可计数数字。迭...
    99+
    2023-07-05
  • 如何使用迭代器模式
    这篇文章主要讲解了“如何使用迭代器模式”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用迭代器模式”吧!你将学到迭代器模式的含义实现一个数组迭代器实现一...
    99+
    2022-10-19
  • C#中如何使用迭代器
    今天就跟大家聊聊有关C#中如何使用迭代器,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。创建迭代器最常用的方法是对 IEnumerable 接口实现 GetEnumerator 方法,...
    99+
    2023-06-18
  • C++中如何使用迭代器
    本篇文章给大家分享的是有关C++中如何使用迭代器,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。标准库为每一种标准容器(包括 vector)定义了一种迭代器类型。迭代器类型提供了...
    99+
    2023-06-17
  • Python迭代器如何创建使用
    这篇文章主要介绍“Python迭代器如何创建使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python迭代器如何创建使用”文章能帮助大家解决问题。Python 迭代器迭代器是一种对象,该对象包含...
    99+
    2023-07-06
  • Node.js 中异步迭代器如何使用
    这篇文章将为大家详细讲解有关Node.js 中异步迭代器如何使用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。什么是异步迭代器异步迭代器实际上是以前迭代器的...
    99+
    2022-10-19
  • Node.js 中如何使用异步迭代器
    这期内容当中小编将会给大家带来有关Node.js 中如何使用异步迭代器,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。在 Events 中使用 asyncIteratorN...
    99+
    2022-10-19
  • Qt的遍历迭代器如何使用
    今天小编给大家分享一下Qt的遍历迭代器如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。前言:Qt(官方发音 [kju:...
    99+
    2023-06-29
  • 如何在PHP中使用迭代器模式
    这篇文章给大家介绍如何在PHP中使用迭代器模式,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。php的框架有哪些php的框架:1、Laravel,Laravel是一款免费并且开源的PHP应用框架。2、Phalcon,Ph...
    99+
    2023-06-14
  • Python迭代器是什么及如何使用
    Python 迭代器迭代器是一种对象,该对象包含值的可计数数字。迭代器是可迭代的对象,这意味着您可以遍历所有值。从技术上讲,在 Python 中,迭代器是实现迭代器协议的对象,它包含方法 iter() 和 next()。迭代器 VS 可迭代...
    99+
    2023-05-14
    Python
  • 如何在java项目中使用迭代器
    如何在java项目中使用迭代器?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 迭代器模式将一个集合给封装起来,主要是为用户提供了一种遍历其内部元素的方式。迭代器模式有...
    99+
    2023-05-31
    java 迭代器 ava
  • python如何使用生成器的next()迭代
    这篇文章将为大家详细讲解有关python如何使用生成器的next()迭代,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。生成器的next()迭代在编程中的大多数正常情况下,可以访问一个索引,并使用计数器获取...
    99+
    2023-06-27
  • Python异步之迭代器如何使用详解
    目录正文1. 什么是异步迭代器1.1. Iterators1.2. Asynchronous Iterators2. 什么是“async for”循环?3. ...
    99+
    2023-03-22
    Python异步迭代器 Python异步
  • 使用Java如何自定义一个迭代器
    使用Java如何自定义一个迭代器?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。具体如下:编写自己的Iterator,实现Iterator接口,这里多说一句,实现Iterab...
    99+
    2023-05-31
    java 自定义 迭代器
  • Iterator迭代器如何在Java项目中使用
    Iterator迭代器如何在Java项目中使用?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。什么是迭代器  在Java中,有很多的数据容器,对于这些的操作有很多的共性。Java...
    99+
    2023-05-31
    java iterator ava
  • java迭代器iterator怎么使用
    在Java中,迭代器(Iterator)是用来遍历集合(Collection)中元素的工具。迭代器提供了一种统一的方式来访问集合中的...
    99+
    2023-10-18
    java
  • C++迭代器iterator怎么使用
    C++迭代器(iterator)是一种用于访问容器中元素的对象,可以用来遍历容器中的元素,或者修改容器中的元素。首先,你需要在代码中...
    99+
    2023-08-15
    C++ iterator
  • python如何使用enumerate()进行迭代
    这篇文章将为大家详细讲解有关python如何使用enumerate()进行迭代,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。使用enumerate()而不是range(len())进行迭代如果我们需要遍历...
    99+
    2023-06-27
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作