设计模式GOF23--迭代器模式

场景

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

代码解析

1
2
3
4
5
6
7
8
9
10
11
12
13
/**
* 迭代器接口
*/
public interface MyIterator {
void first(); //将游标指向第一个元素
void next(); //将游标指向下一个元素
boolean hasNext(); //判断是否存在下一个元素

boolean isFirst();
boolean isLast();

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

定义内部聚合类

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
/**
* 自定义的聚合类
*/
public class ConcrtetMyAggregate {
private List<Object> list = new ArrayList<>();

public ConcrtetMyAggregate() {

}

public void addObject(Object object){
this.list.add(object);
}

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 void next() {
if (cursor<list.size()){
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 Object getCurrentObj() {
return list.get(cursor);
}
}
}

调用

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
/**
* 迭代器模式
*/
public class Client {
public static void main(String[] args) {
ConcrtetMyAggregate cma = new ConcrtetMyAggregate();
cma.addObject("aa");
cma.addObject("bb");
cma.addObject("cc");

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

基本案例

  • 实现正向遍历的迭代器
  • 实现逆向遍历的迭代器

开发中常见的场景

  • JDK内置的迭代器(List/Set)
注:该博文为学习总结,视频来源为高淇java300集