定义

迭代器模式(Iterator Pattern)是 Java 和 .Net 编程环境中非常常用的设计模式。这种模式用于顺序访问集合对象的元素,不需要知道集合对象的底层表示。

场景

  • 提供一种可以遍历聚合对象的方式,又称游标cursor模式
  • 聚合对象:存储数据
  • 迭代器:遍历数据

例子

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
// 自定义的迭代器接口
public interface MyIterator {
// 将游标指向第一个元素
void first();
// 将游标指向下一个元素
void next();
// 判断是否存在下一个元素
boolean hasNext();

boolean isFirst();

boolean isLast();

// 获取当前游标指向的对象
Object getCurrentObj();
}


// 自定义的聚合类
public class ConcreteMyAggregate {
private List<Object> list = new ArrayList<>();

public void addObject(Object obj){
this.list.add(obj);
}
public void removeObject(Object obj){
this.list.remove(obj);
}

public List<Object> getList() {
return list;
}

public void setList(List<Object> list) {
this.list = list;
}

// 获得迭代器
public MyIterator createIterator(){
return new ConcreteIterator();
}

// 使用内部类定义迭代器,可以直接使用外部类的属性
private class ConcreteIterator implements MyIterator {

private int cursor; //定义游标用于记录遍历时的位置

@Override
public void first() {
cursor = 0;
}
@Override
public Object getCurrentObj() {
return list.get(cursor);
}
@Override
public boolean hasNext() {
if(cursor < list.size()){
return true;
}
return false;
}
@Override
public boolean isFirst() {
return cursor==0?true:false;
}
@Override
public boolean isLast() {
return cursor==(list.size()-1)?true:false;
}
@Override
public void next() {
if(cursor < list.size()){
cursor++;
}
}
}
}

public class Client {

public static void main(String[] args) {
ConcreteMyAggregate cma = new ConcreteMyAggregate();
cma.addObject("aa");
cma.addObject("bb");
cma.addObject("cc");

MyIterator iter = cma.createIterator();
while(iter.hasNext()){
System.out.println(iter.getCurrentObj());
iter.next();
}

}
}