zoukankan      html  css  js  c++  java
  • 迭代器模式(完全理解此模式)

    重要的思想:对容器项目遍历从容器本身中分离出来,而放入单独的迭代器中。  其实有种java内部类的意思。

    个人总结,迭代器非常简单直接,超级实用,但是一般流行语言,容器都已经实现了。list, array. 等都已经实现了。

    其他大部分实际开发中不用的模式都是因为场合少,这个是个反例,是因为实在太实用,而被系统api实现了,导致我们基本不会去实现这个设计模式!

    //需求:给一个数字,实现从这这个数字开始,到0结束。
    //实现递减1的遍历。  再实现递减2的遍历。 再实现其他递减规则的遍历.再。。。。。。
    //可以发现让容器实现迭代的接口,那么就需要很多迭代器。而用组合,包含一个实现了迭代器的对象。那么就把变化赶到了类的外边。
    public class MyIterator
    {
        public void Run()
        {
            TheSmartContainer smartContainer=new TheSmartContainer();
            while (smartContainer.mTheIterator.hasNext())
            {
                LSComponentsHelper.LS_Log.Log_INFO(smartContainer.mTheIterator.next()+"");
            }
        }
    
        //region 简单实现迭代器的接口,发现每一个需求,都必须继承一次。继承的痛点,完全不符合开闭原则.
        public interface TheIterator
        {
            public boolean hasNext();
            public Object next();
        }
    
        public class TheContainer implements TheIterator
        {
            private int theNum=0;
    
            public TheContainer(int a)
            {
                theNum=a;
            }
    
    
            @Override
            public boolean hasNext()
            {
                return theNum>=0;
            }
    
            @Override
            public Object next()
            {
                return theNum--;
            }
        }
        //endregion
    
    
        //region 不再直接实现迭代器接口,而让强制让迭代器容器包含一个迭代器。那么也就等于容器有了迭代功能,而且把迭代器的具体实现放入到外部。吻合开闭原则
        public interface ISmartContainer
        {
            public TheIterator getIterator();
        }
    
        public class TheSmartContainer implements ISmartContainer
        {
            private int mynum=10;
            public TheIterator mTheIterator;
            public TheSmartContainer()
            {
                mTheIterator=getIterator();
            }
            @Override
            public TheIterator getIterator()
            {
                //return new myiterator1();
                return new myiterator2(); //随时切换迭代逻辑。完美实现开闭原则
            }
    
            public class myiterator1 implements TheIterator
            {
    
                @Override
                public boolean hasNext()
                {
                    return mynum>=0;
                }
    
                @Override
                public Object next()
                {
                    return mynum--;
                }
            }
    
            public class myiterator2 implements TheIterator
            {
    
                @Override
                public boolean hasNext()
                {
                    return mynum>0;
                }
    
                @Override
                public Object next()
                {
                    mynum-=2;
                    return mynum;
                }
            }
        }
        //endregion
    }
  • 相关阅读:
    制作在线简历(一)——Loading与底部菜单
    然而这并没有什么卵用
    移动开发中Fiddler的那些事儿
    多种方法实现Loading(加载)动画效果
    总结)Nginx/LVS/HAProxy负载均衡软件的优缺点详解
    SQLServer和MySQL job和 event定时器的差别
    全局ID的重要性
    Windows操作系统上各种服务使用的端口号, 以及它们使用的协议的列表
    Linux发展历史图
    奇特的Local System权限(转载)
  • 原文地址:https://www.cnblogs.com/lsfv/p/11143745.html
Copyright © 2011-2022 走看看