码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 设计模式学习(十八):迭代器模式


    设计模式学习(十八):迭代器模式

    作者:Grey

    原文地址:

    博客园:设计模式学习(十八):迭代器模式

    CSDN:设计模式学习(十八):迭代器模式

    迭代器模式

    迭代器模式是一种行为型模式。

    迭代器最典型的应用是容器遍历

    img

    模仿 JDK 的容器,我们自定义一个容器并实现 iterator 方法;

    首先,我们先定义一个容器接口

    public interface Collection_<E> {
        int size();
    
        void add(E element);
    
        Iterator_<E> iterator();
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    里面包括了一个 iterator 方法,所以每个实现这个容器接口的具体容器类型,都必须自定义 iterator 方法, 然后定义一个 Iterator 接口 Iterator_, 具体容器中可以增加一个内部类来专门实现这个接口,

    比如我们的具体容器类是 ArrayList_

    import static java.lang.System.arraycopy;
    
    public class ArrayList_<E> implements Collection_<E> {
        private E[] objects = (E[]) new Object[10];
        private int index = 0;
    
        @Override
        public int size() {
            return index;
        }
    
        @Override
        public void add(E element) {
            if (objects.length == size()) {
                // 满了就扩容为原来的两倍
                E[] newObjects = (E[]) new Object[objects.length * 2];
                arraycopy(objects, 0, newObjects, 0, objects.length);
                objects = newObjects;
            }
            objects[index] = element;
            index++;
        }
    
        @Override
        public Iterator_<E> iterator() {
            return new ArrayListIterator_<>();
        }
    
        private class ArrayListIterator_<E> implements Iterator_<E> {
            private int currentIndex = 0;
    
            @Override
            public boolean hasNext() {
                return currentIndex < index;
            }
    
            @Override
            public E next() {
                E o = (E) objects[currentIndex];
                currentIndex++;
                return o;
            }
        }
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45

    我们主要看 ArrayListIterator_这个内部类,里面其实是实现了 Iterator_ 这个接口,所以 ArrayList_ 的遍历操作会执行这个内部类中的操作规则来对其进行遍历。

    如何实现一个快照迭代器

    我们可以在容器中,为每个元素保存两个时间戳,一个是添加时间戳 addTimestamp,一个是删除时间戳 delTimestamp。

    当元素被加入到集合中的时候,我们将 addTimestamp 设置为当前时间,将 delTimestamp 设置成最大长整型值(Long.MAX_VALUE)。

    当元素被删除时,我们将 delTimestamp 更新为当前时间,表示已经被删除。

    注意,这里只是标记删除,而非真正将它从容器中删除。

    同时,每个迭代器也保存一个迭代器创建时间戳 snapshotTimestamp,也就是迭代器对应的快照的创建时间戳。

    当使用迭代器来遍历容器的时候,只有满足

    addTimestamp < snapshotTimestamp < delTimestamp
    
    • 1

    的元素,才是属于这个迭代器的快照。如果元素的

    addTimestamp > snapshotTimestamp
    
    • 1

    说明元素在创建了迭代器之后才加入的,不属于这个迭代器的快照;

    如果元素的

    delTimestamp < snapshotTimestamp
    
    • 1

    说明元素在创建迭代器之前就被删除掉了,也不属于这个迭代器的快照。

    这样就在不拷贝容器的情况下,在容器本身上借助时间戳实现了快照功能。

    迭代器模式应用

    • MyBatis 中的 DefaultCursor

    它实现了 Cursor 接口,而且定义了一个成员变量 cursorIterator,其定义的类型为 CursorIterator 。继续查看 CursorIterator 类的源码实现,它是 DefaultCursor 的一个内部类,并且实现了 JDK 中的 Iterator 接口。

    UML 和 代码

    UML 图

    代码

    更多

    设计模式学习专栏

    参考资料

    • Effective Java中文版(第3版)

    • Head First 设计模式

    • 设计模式-可复用面向对象软件的基础

    • 坦克大战-马士兵

    • 菜鸟教程-设计模式

    • 极客时间-设计模式之美-王争

  • 相关阅读:
    h5利用canvas截取video视频
    微服务项目:尚融宝(49)(核心业务流程:标的管理(1))
    前端工程师应该如何去创业?
    vSAN数据恢复-vSAN架构下虚拟机磁盘组件出现问题的数据恢复案例
    系列十三、Redis的哨兵机制
    数据结构 - 链表
    【初阶数据结构】详解树和二叉树(一) - 预备知识(我真的很想进步)
    大数据分布式计算工具Spark实战讲解(数据输入实战)
    封装、继承、多态的概念和其中的区别
    6.DesignForPlacement\PlaceHighlightedSymbols
  • 原文地址:https://blog.csdn.net/hotonyhui/article/details/127820807
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号