迭代器模式:
在软件构建过程中,集合对象内部结构常常变化各异(比如各种不同的集合对象list,set,map)。但对于这些集合对象,我们希望在不暴露其内部结构的同时,可以让外部客户代码透明地访问其中包含的元素;在面向对象技术中,将这种遍历机制抽象为“迭代器对象”,它为“应对变化中的集合对象”提供了一种优雅的方法。
适用性:
1.访问一个聚合对象的内容而无需暴露它的内部表示。
2.支持对聚合对象的多种遍历。
3.为遍历不同的聚合结构提供一个统一的接口(即, 支持多态迭代)。
/**
* 聚集抽象类
*/
public abstract class Aggregate {
// 创建迭代器
public abstract Iterator createIteraotr();
}
Java代码
/**
* 具体的聚集类,继承聚集抽象类Aggregate
*/
public class ConcreteAggregate extends Aggregate{
// 声明一个List泛型变量,用于存放聚合对象
private List<Object> items = new ArrayList<Object>();
@Override
public Iterator createIteraotr() {
return new ConcreteIterator(this);
}
// 返回集合总个数
public int count(){
return items.size();
}
public List<Object> getItems() {
return items;
}
public void setItems(List<Object> items) {
this.items = items;
}
}
Java代码
/**
* 迭代器抽象类
*/
public abstract class Iterator {
// 开始对象
public abstract Object first();
// 下一个对象
public abstract Object next();
// 当前对象
public abstract Object currentItem();
// 是否到结尾
public abstract boolean isDone();
}
Java代码
/**
* 具体的迭代器类,继承迭代器抽象类Iterator
*/
public class ConcreteIterator extends Iterator{
// 定义一个具体的聚集对象
private ConcreteAggregate aggregate;
private int current =0 ;
// 初始化时将具体的聚集对象传入
public ConcreteIterator(ConcreteAggregate aggregate){
this.aggregate =aggregate;
}
@Override
public Object currentItem() {
// 返回当前的聚集对象
return aggregate.getItems().get(current);
}
@Override
public Object first() {
// 得到聚集的第一个对象
return aggregate.getItems().get(0);
}
@Override
public boolean isDone() {
// 判断当前是否遍历到结尾,到结尾返回true
return current>=aggregate.count()?true:false;
}
@Override
public Object next() {
// 得到聚集的下一个对象
Object ref = null;
current++;
if(current<aggregate.count()){
ref = aggregate.getItems().get(current);
}
return ref;
}
}
Java代码
/**
* 反向遍历的具体的迭代器类,继承迭代器抽象类Iterator
*/
public class ConcreteIteratorDesc extends Iterator{
// 定义一个具体的聚集对象
private ConcreteAggregate aggregate;
private int current =0 ;
// 初始化时将具体的聚集对象传入
public ConcreteIteratorDesc(ConcreteAggregate aggregate){
this.aggregate =aggregate;
current = aggregate.count()-1;
}
@Override
public Object currentItem() {
// 返回当前的聚集对象
return aggregate.getItems().get(current);
}
@Override
public Object first() {
// 得到聚集的第一个对象
return aggregate.getItems().get(aggregate.count()-1);
}
@Override
public boolean isDone() {
// 判断当前是否遍历到结尾,到结尾返回true
return current<0?true:false;
}
@Override
public Object next() {
// 得到聚集的下一个对象
Object ref = null;
current--;
if(current>=0){
ref = aggregate.getItems().get(current);
}
return ref;
}
}
Java代码
public class Main {
public static void main(String[] args) {
// 聚集对象(公交车)
ConcreteAggregate a = new ConcreteAggregate();
// 对象集合(新上来的乘客)
List<Object> items = new ArrayList<Object>();
items.add("大鸟");
items.add("小菜");
items.add("行李");
items.add("老外");
items.add("公交内部员工");
items.add("小偷");
a.setItems(items);
// 迭代器对象
Iterator i = new ConcreteIterator(a);
// 迭代器第一个对象(从第一个乘客开始)
Object item = i.first();
while(!i.isDone()){
System.out.println(i.currentItem()+"请买车票");
i.next();
}
System.out.println("------------反向遍历---------------");
//-----反向遍历-------------------
Iterator iDesc = new ConcreteIteratorDesc(a);
// 迭代器第一个对象(从最后一个乘客开始)
Object item2 = iDesc.first();
while(!iDesc.isDone()){
System.out.println(iDesc.currentItem()+"请买车票");
iDesc.next();
}
}
}
分享到:
相关推荐
设计模式的迭代器模式的例子,希望对大家有用~~~~~~~~
设计模式之迭代器模式 设计模式之迭代器模式 设计模式之迭代器模式
迭代器模式Demo
23种设计模式之迭代器模式对迭代器模式进行了简单的介绍,并附带了例子程序,和大家分享
设计模式-迭代器模式(讲解及其实现代码)
迭代器模式的示例代码和文档,学习迭代器模式的参考资料。
一个聚合对象,如一个列表(List)或者一个集合(Set),应该提供一种方法来让别人可以访问它...怎样遍历一个聚合对象,又不需要了解聚合对象的内部结构,还能够提供多种不同的遍历方式,这就是迭代器模式所要解决的问题。
使用composite模式构成二叉树,并用迭代器模式封装访问,前序、中序和后序的遍历。JAVA 编写。 Main中直接运行
迭代器模式demo
C#面向对象设计模式 (行为型模式) Iterator 迭代器模式 视频讲座下载
设计模式--迭代器模式java例子
迭代器模式(Iterator),提供一种方法顺序访问一个聚合对象中各个元素,而又不暴露该对象的内部表示。 那么一般在什么时候才会用迭代器模式呢?当你需要访问一个聚集对象,而且不管这些对象是什么都需要遍历的时候...
java设计模式--迭代器模式,理解这个例子就完全理解迭代器啦
迭代器(Iterator) 用意:可以顺序地访问一个集合中的元素而不必暴露集合中的内部表象。
Headfirst第九章迭代器模式C++实现代码 ,并附加相应的UML类图
迭代器模式(Iterator Pattern)是设计模式中的一种行为模式,它允许顺序访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示。迭代器模式提供了一种方法,可以顺序地访问一个聚合对象中的各个元素,而又...
【Java设计模式】(1)迭代器模式Iterator(代码)