• 迭代器模式(完全理解此模式)


    重要的思想:对容器项目遍历从容器本身中分离出来,而放入单独的迭代器中。  其实有种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
    }
  • 相关阅读:
    css和js实现硬件加速渲染自定义滚动条
    入驻博客园
    原生JS实现动态折线图
    纯JS自定义网页滚动条
    Unity实现代码控制音频播放
    MVC实现修改数据
    JS实现将二维数组生成到页面上
    JS实现页面计时
    多中方式,实现斐波那契数列
    算法题
  • 原文地址:https://www.cnblogs.com/lsfv/p/11143745.html
Copyright © 2020-2023  润新知