迭代器模式提供了一种方法顺序访问一个聚合对象中的各个元素,而不暴露其内部的表示。
迭代模式与组合模式要点:
1.迭代器允许访问聚合的元素,而不需要暴露它的内部结构
2.迭代器将遍历聚合的工作封装进一个对象中
3.当使用迭代器的时候,我们一来聚合提供遍历
4.迭代器提供了一个通用的接口,让我们遍历聚合的项时,就可以使用多态机制
5.我们应该努力让一个类只分配一个责任
6.组合模式提供一个结构,可同时包容个别对象和组合对象
7.组合模式允许客户对个别对象以及组合对象一视同仁
8.组合结构内的任意对象称为组件,组件可以使组合,也可以是叶子节点
9.在实现组合模式时,有许多设计上的折衷。你要根据需要平衡透明性和安全性
好处:
1. 支持以不同的方式遍历一个容器角色。根据实现方式的不同,效果上会有差别
2. 简化了容器的接口。但是在java Collection中为了提高可扩展性,容器还是提供了遍历的接口
3. 对同一个容器对象,可以同时进行多个遍历。因为遍历状态是保存在每一个迭代器对象中的
由此也能得出迭代器模式的适用范围:
1. 访问一个容器对象的内容而无需暴露它的内部表示
2. 支持对容器对象的多种遍历
3. 为遍历不同的容器结构提供一个统一的接口(多态迭代)
意义:这个模式给你提供了一种方法,可以顺序访问一个聚集对象中的元素,而又不用知道内部是如何表示的。在设计中使用迭代器的影响是明显的:如果你有一个统一的方法访问聚合中的每一个对象,你就可以编写多态的代码和这些聚合搭配,使用---如同前面的printMenu()方法一样,只要有了迭代器这个方法根本不管菜单项究竟是由数组还是有ArrayList来保存。另一个对设计造成重要影响的,是迭代器模式把在元素之间游走的责任交给迭代器,而不是聚合对象。这不仅让聚合的接口和实现变得更简洁,也可以让聚合更专注它所应该专注的事情上面来。
组合模式:允许你讲对象组成属性结构。组合能让客户以一致的方式处理个别对象和对象组合。
1.组合模式让我们能用树形方式创建对象的结构,树里面包含了组合以及个别的对象
2.使用组合结构,我们能把相同的操作应用在组合和个别对象上。换句话说,在大多数情况下,我们可以忽略对象组合和个别对象之间的差别。
单一责任原则:一个类应该只有一个引起变化的原因。