设计模式-迭代器模式
背景
每次想起学生时代,经常性点名,第头来,第尾来,乱来,呵呵,老师的点名方式五花8门...而点这种就类似到遍历,我们设计模式中的迭代器一样的逻辑,从头到尾或按照想要的规则来...
迭代器模式是什么?
迭代器模式(Iterator Pattern)属于行为型模式。提供一种方法顺序访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示。
角色:
Iterator:迭代器接口。定义访问和遍历元素的接口。
ConcreteIterator:具体的迭代器实现对象。实现取聚合对象的遍历,并跟踪遍历时的当前位置。
Aggregate:聚合对象。定义创建相应迭代器对象的接口。
ConcreteAggregate:具体聚合对象。实现创建相应的迭代器对象。
迭代器模式可以干嘛?
迭代器,以一个统一的方式来访问内部实现不同的取合对象。主要解决一个数据元素遍历问题,还有如何遍历。将需要遍历的元素放到池中,然后根据所需的遍历方式进行遍历。
本质:”控制访问聚合对象中的元素“。
优点:
高内聚:将数据聚合为一个容器中,以不同方式遍历。
单一责职:容器是负责存放数据、而遍历是负责打印数据,这样就是即解耦又责职单一。
开闭原则:很好的遵循该点,因为新增的遍历方式不影响现有的遍历方式,可以不断拓展新的遍历方式;
缺点:
增加系统复杂度:由于迭代的算法可以不断新增,所以会造成每一个新算法可以新增一个类,会导致系统复杂度会变高。
个人理解:
迭代,就类似于点名,而学生全部在班级里面,属于容器(container),班级是一个容器,学生属于每一个元素,老师点名的方式就是迭代的方法,从头到尾,从尾到头...
迭代器模式类图
源码下载:https://gitee.com/hong99/design-model/issues/I1IMES
实现代码
/**
* @Auther: csh
* @Date: 2020/6/9 10:17
* @Description:迭代抽象接口(Iterator)
*/
public interface Iterator {
//遍历所有元素
void printElements();
}
/**
* @Auther: csh
* @Date: 2020/6/9 10:18
* @Description:数据容器接口(Container)
*/
public abstract class Container {
//容器数据
public abstract void setContainer(List list);
}
/**
* @Auther: csh
* @Date: 2020/6/9 10:21
* @Description:迭代实现(ConcreteIterator)
*/
public class IteratorImpl extends Container implements Iterator {
//聚合对象(Aggregate)
private List list =new ArrayList();
@Override
public void printElements() {
if(null!=list){
for (Object o : list) {
System.out.println(o);
}
}
}
@Override
public void setContainer(List list) {
this.list =list;
}
}
/**
* @Auther: csh
* @Date: 2020/6/9 10:29
* @Description:班级点名
*/
public class Client {
public static void main(String[] args) {
//具体的对象 ConcreteAggregate
String concreteAggregate = "小明,小红,小芳,小丽,小娟,小军,小刚,小强,小方,晓明,晓红,晓芳,晓丽,晓娟,晓军,晓刚,晓强,晓方";
String[] arr = concreteAggregate.split(",");
List list = new ArrayList(Arrays.asList(arr));
IteratorImpl iterator = new IteratorImpl();
iterator.setContainer(list);
iterator.printElements();
}
}
结果
小明
小红
小芳
小丽
小娟
小军
小刚
小强
小方
晓明
晓红
晓芳
晓丽
晓娟
晓军
晓刚
晓强
晓方
源码下载:https://gitee.com/hong99/design-model/issues/I1IMES
最后
本例是通过for基础上去实现的,主要为传播迭代器的一种思想,具体怎么实现其实在很多实际工作中不是很重要,重要的是基本的实现原理思想和选型。迭代器在jdk中到处应用,for arrylist linklist等等,该模式还是比较简单,复杂在具体基础上去应用一些算法。
java的迭代器
Iterable
list
set
....
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- NetCore配置框架详解
- 初识ABP vNext(11):聚合根、仓储、领域服务、应用服务、Blob储存
- 群组复制MySQL Group Replication
- 关于自定义单选框InfoPreference的笔记
- Python爬虫之gerapy爬虫管理
- 内存地址中藏着的学问
- Python爬虫之crawlspider类的使用
- 数据结构 - 堆(Heap)
- 信息收集之主机发现:masscan
- 信息收集之社工字典
- CloudBase CMS 2.0 焕新升级,从「心」出发!
- 使用MySQL Keyring 的 SECRET类型密钥执行非对称加密
- node egg 实现跨域
- 使用Markdown画流程图
- HBase NotServingRegionException