开发者社区> 桃子红了呐> 正文

JAVA设计模式之【迭代器模式】

简介:
+关注继续查看
迭代器模式    聚合类,聚合对象    电视机遥控器,迭代器,遍历局和对象中的成员    灵活新增遍历方法    将负责遍历数据的方法提取出来,封装到专门的类中,实现数据存储和数据遍历分离。这就是迭代器模式。    灵活性,可扩展性,避免类职责过多    角色        抽象迭代器Iterator            定义访问和遍历数据的接口        具体迭代器ConcreteIterator            实现接口,完成对聚合对象的遍历            通过游标来记录当前位置        抽象聚合类Aggregate            用于存储和管理元素对象,有一个createIterator方法,用于创造迭代器        具体聚合类ConcreteAggregate            实现createIterator方法

看例子,电视遥控器遍历数据

1.迭代器接口,抽象迭代器

package Iterator;

/**
 * Created by Jiqing on 2016/10/27.
 */
public interface Television {
    TVIterator createIterator();
}

2.电视接口,抽象聚合类

package Iterator;

/**
 * Created by Jiqing on 2016/10/27.
 */
public interface Television {
    TVIterator createIterator();
}

3.具体聚合类和迭代器类

package Iterator;

/**
 * Created by Jiqing on 2016/10/27.
 */
public class TCLTelevision implements Television{
    private Object[] obj = {"湖南卫视","北京卫视","上海卫视"};
    public TVIterator createIterator() {
        return new TCLIterator();
    }

    class TCLIterator implements TVIterator {
        private int currentIndex = 0;
        public void next() {
            if (currentIndex < obj.length) {
                currentIndex ++ ;
            }
        }

        public void previous()
        {
            if(currentIndex>0)
            {
                currentIndex--;
            }
        }

        public void setChannel(int i)
        {
            currentIndex=i;
        }


        public Object currentChannel()
        {
            return obj[currentIndex];
        }

        public boolean isLast()
        {
            return currentIndex==obj.length;
        }

        public boolean isFirst()
        {
            return currentIndex==0;
        }
    }
}

4.客户端

package Iterator;

/**
 * Created by Jiqing on 2016/10/27.
 */
public class Client {
    public static void display(Television tv) {
        TVIterator i = tv.createIterator();
        System.out.println("电视机频道:");
        while (!i.isLast()) {
            System.out.println(i.currentChannel().toString());
            i.next();
        }
    }

    public static void reverseDisplay(Television tv) {
        TVIterator i = tv.createIterator();
        i.setChannel(3);
        System.out.println("逆向遍历电视机频道:");
        while(!i.isFirst())
        {
            i.previous();
            System.out.println(i.currentChannel().toString());
        }
    }

    public static void main(String a[])
    {
        Television tv;
        tv= new TCLTelevision();
        display(tv);
        System.out.println("--------------------------");
        reverseDisplay(tv);
    }
}

执行结果:

电视机频道:
湖南卫视
北京卫视
上海卫视
--------------------------
逆向遍历电视机频道:
上海卫视
北京卫视
湖南卫视

422101-20161027004421906-1830286910.png



本文转自TBHacker博客园博客,原文链接:http://www.cnblogs.com/jiqing9006/p/6002502.html,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
【蓝桥Java每日一练】——9.回文链表
今天带来一道能检验链表基础的题,题目比较简单,但是想通过确实容易,但想使用更好复杂度的方法却不容易。
3 0
【蓝桥Java每日一练】————6.二叉树的前中后序遍历(递归与迭代)(上)
今天给大家带来的每日一题是二叉树的前中后序遍历(其实是三题哈哈哈哈哈),二叉树是非常非常重要的基础结构,其中它的前中后序三种遍历又显得尤为基础和重要。每日一练的目的更多是和大家巩固基础能力,会则巩固之,不会更应学习之。
4 0
【蓝桥Java每日一练】————6.二叉树的前中后序遍历(递归与迭代)(下)
【蓝桥Java每日一练】————6.二叉树的前中后序遍历(递归与迭代)
4 0
【蓝桥Java每日一练】——7.至少是其他数字两倍的最大数
今天带来的每日一题,是昨天的每日一题——至少是其他数字两倍的最大数。
4 0
【蓝桥Java每日一练】——8.计算力扣银行的钱
【蓝桥Java每日一练】——8.计算力扣银行的钱
3 0
高频考题!数组中找重复数字(算法 NO.1)
本题来自 LeetCode 中国网站,属于算法面试中的一道经典高频考题。题解由 Doocs 开源社区 leetcode 项目维护者提供。
4 0
C语言基础知识(三)-程序设计结构、数组、字符串处理函数(下)
数组 一维数组 一维数组的定义 数组内存是连续的 数组的初始化 二维数组 二维数组的定义 二维数组的初始化 数组小结 字符数组和字符串 字符串结束标志(划重点) 字符串长度 实例 数组元素的查询 对无序数组的查询 对有序数组的查询 字符串处理函数 字符串连接函数 strcat() 字符串复制函数 strcpy() 字符串比较函数 strcmp()
4 0
4269
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载