提供一种方法顺序访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示。

迭代器模式(Iterator)实际上在Java的集合类中已经广泛使用了。我们以List为例,要遍历ArrayList,即使我们知道它的内部存储了一个Object[]数组,也不应该直接使用数组索引去遍历,因为这样需要了解集合内部的存储结构。如果使用Iterator遍历,那么,ArrayList和LinkedList都可以以一种统一的接口来遍历:

List list = ...

for (Iterator it = list.iterator(); it.hasNext(); ) {

String s = it.next();

}

实际上,因为Iterator模式十分有用,因此,Java允许我们直接把任何支持Iterator的集合对象用foreach循环写出来:

List list = ...

for (String s : list) {

}

然后由Java编译器完成Iterator模式的所有循环代码。

虽然我们对如何使用Iterator有了一定了解,但如何实现一个Iterator模式呢?我们以一个自定义的集合为例,通过Iterator模式实现倒序遍历:

public class ReverseArrayCollection implements Iterable {

// 以数组形式持有集合:

private T[] array;

public ReverseArrayCollection(T... objs) {

this.array = Arrays.copyOfRange(objs, 0, objs.length);

}

public Iterator iterator() {

return ???;

}

}

实现Iterator模式的关键是返回一个Iterator对象,该对象知道集合的内部结构,因为它可以实现倒序遍历。我们使用Java的内部类实现这个Iterator:

public class ReverseArrayCollection implements Iterable {

private T[] array;

public ReverseArrayCollection(T... objs) {

this.array = Arrays.copyOfRange(objs, 0, objs.length);

}

public Iterator iterator() {

return new ReverseIterator();

}

class ReverseIterator implements Iterator {

// 索引位置:

int index;

public ReverseIterator() {

// 创建Iterator时,索引在数组末尾:

this.index = ReverseArrayCollection.this.array.length;

}

public boolean hasNext() {

// 如果索引大于0,那么可以移动到下一个元素(倒序往前移动):

return index > 0;

}

public T next() {

// 将索引移动到下一个元素并返回(倒序往前移动):

index--;

return array[index];

}

}

}

使用内部类的好处是内部类隐含地持有一个它所在对象的this引用,可以通过ReverseArrayCollection.this引用到它所在的集合。上述代码实现的逻辑非常简单,但是实际应用时,如果考虑到多线程访问,当一个线程正在迭代某个集合,而另一个线程修改了集合的内容时,是否能继续安全地迭代,还是抛出ConcurrentModificationException,就需要更仔细地设计。

练习

小结

Iterator模式常用于遍历集合,它允许集合提供一个统一的Iterator接口来遍历元素,同时保证调用者对集合内部的数据结构一无所知,从而使得调用者总是以相同的接口遍历各种不同类型的集合。

java迭代器逆序_迭代器相关推荐

  1. Java LinkedHashMap 逆序遍历

    利用:ListIterator<pre name="code" class="java">previous 代码如下 public static v ...

  2. java 链表逆序代码_如何实现一个高效的单向链表逆序输出?(详解)

    需要考虑因素,高效应权衡多方面因素 数据量是否会很大 空间是否有限制 原始链表的结构是否可以更改 时间复杂度是否有限制 一个链表节点需要输出的元素有多个,例如链表中存的是自定义对象,有多个字段 题目. ...

  3. Java二叉树逆序遍历_二叉树遍历小结

    二叉树遍历小结 声明 0 二叉树遍历概述 二叉树遍历:按照既定序,对每个节点仅访问一次: 二叉树非递归遍历思想:参考这篇博文,核心思想是存在重合元素的局部有序保证整体有序,由于二叉树的结构特点,二叉树 ...

  4. python将字符串逆序_为什么说Python是一门伟大的入门语言?(附免费教程)

    Python 是一门伟大的入门语言.作为一门伟大的编程语言,一定要具备一些特征,其中有五项特征是非常重要的: 非常棒的首次体验:就像书的开始,首先一定要能够"沉迷",学习新知识一定 ...

  5. java string逆序_Java学习笔记(八)——异常

    本节主要内容是对 Java 的异常处理进行讲解,主要包含以下知识点: 异常分类 声明及抛出 捕获异常 自定义异常 * 异常堆栈 异常概述 对于程序的错误以及外部环境能够对用户造成的影响,我们应当及时报 ...

  6. java string逆序_java经典入门算法题,java初学者必备

    java经典入门算法题 开头求关注警告 喜欢这样文章的可以关注我,我会持续更新,你们的关注是我更新的动力!需要更多java学习资 料的也可以私信我! 祝关注我的人都:身体健康,财源广进,福如东海,寿比 ...

  7. java list逆序_Java使用ListIterator逆序ArrayList

    对于列表而言,除了Iterator,还提供了一个功能更加强大的ListIterator.它可以实现逆序遍历列表中的元素.本示例将使用其逆序遍历ArrayList. 思路分析:要逆序遍历某个列表,首先要 ...

  8. java list逆序_Java的数组和list升序,降序,逆序函数Collections.sort和Arrays.sort的使用...

    list升序,降序,逆序 Listlist =new ArrayList(); //如果list是 5 7 2 6 8 1 4 1.升序: Collections.sort(list) //list: ...

  9. java 链表逆序 递归,java用递归和非递归实现链表逆序

    传统的逆序链表方法是使用三个指针来记录节点的状态,防止链表断裂. Node节点 public class Node { private int data; private Node next; pub ...

最新文章

  1. [20180317]12c TABLE ACCESS BY INDEX ROWID BATCHED2.txt
  2. %matplotlib inline %config InlineBackend.figure_format = “retina为了将图片嵌入notebook及提高分
  3. 卷积神经网络(CNN)的原理
  4. djano-cms学习笔计(一)
  5. 惠普:利用大数据创造更智能的IT服务台
  6. 【笔记】windows10安装linux(ubuntu)双系统教程(可能是现今最简单方法)
  7. 【转】Android 音量键+电源键 截屏代码小结
  8. shell mysql 取值_shell 脚本中获取mysql多个字段的值
  9. OO第四次总结学期总结
  10. 关闭迅雷首页播放视频的方法
  11. 录屏---EV录屏软件windows下使用说明
  12. 微信小程序点击图片放大
  13. validity.valueMissing无论写不写文本都为false
  14. 北京化工大学计算机考研资料汇总
  15. python如何提取word文档某个段落所有内容(包括段落、表格、图片一并提取)
  16. JPA学习 —— 第五课、JPA常用API详解
  17. RK3588平台开发系列讲解(USB篇)USB 外设 CONFIG
  18. 学习NLP的第9天——基于HanLP实现的拼音转换
  19. SSD的王者 PCIe固态硬盘的未来在哪里
  20. 正点原子ALPHA_字符设备驱动开发总结

热门文章

  1. Order By 排序条件中带参数的写法(Oracle数据库、MyBatis)
  2. 很多人喜欢露脚踝你觉得时尚吗?
  3. python如何实现支持中文
  4. 拓展欧几里得 [Noi2002]Savage
  5. [Grid Layout] Place grid items on a grid using grid-column and grid-row
  6. Extjs 之 initComponent 和 constructor的区别(转)
  7. hdu 2007 - 平方和与立方和
  8. SMTP 服务器要求安全连接或客户端未通过身份验证的各个解决方案(C#)
  9. java接口调试思想
  10. 20180601]函数与标量子查询2.txt