迭代器模式
标签 : Java与设计模式
迭代器模式: 提供一种方法顺序访问聚合对象(如List
、Set
)内的每个元素, 而又不暴露聚合对象的内部实现.
(图片来源: 设计模式: 可复用面向对象软件的基础)
模式实现
Iterator & Aggregate
- Iterator: 迭代器
定义访问和遍历元素的接口 - Aggregate: 聚合
定义创建响应迭代器对象的接口
由于Java已内置了java.lang.Iterable
和java.util.Iterator
接口, 而Iterable
可以作为Aggregate存在(Abstract), 因此在Java中实现迭代器便可不用再定义这两个接口.
ConcreteAggregate & ConcreteIterator
- ConcreteAggregate: 具体聚集
实现Iterable
接口, 返回ConcreteIterator的一个适当的实例; - ConcreteIterator : 具体迭代器
实现Iterator
接口(最好作为具体聚集的内部类), 对该聚集遍历时跟踪当前位置.
public class ConcreteAggregate implements Iterable<String> {
private List<String> list;
public ConcreteAggregate() {
this.list = new ArrayList<>();
}
public void add(String item) {
list.add(item);
}
public String get(int index) {
return list.get(index);
}
@Override
public Iterator<String> iterator() {
return new ConcreteIterator();
}
private class ConcreteIterator implements Iterator<String> {
int cursor = 0;
int lastRet = -1;
@Override
public boolean hasNext() {
return cursor != list.size();
}
@Override
public String next() {
if (cursor >= list.size())
throw new NoSuchElementException();
++cursor;
return list.get((lastRet = cursor - 1));
}
@Override
public void remove() {
list.remove(lastRet);
cursor = lastRet;
lastRet = -1;
}
}
}
public class Client {
@Test
public void client(){
ConcreteAggregate aggregate = new ConcreteAggregate()
aggregate.add("aa")
aggregate.add("bb")
aggregate.add("remove")
aggregate.add("cc")
aggregate.add("dd")
aggregate.add("remove")
aggregate.add("ee")
Iterator<String> iter = aggregate.iterator()
while (iter.hasNext()){
String item = iter.next()
System.out.println(item)
if (item.equals("remove")){
iter.remove()
}
}
System.out.println("********----------********")
for (String item : aggregate){
System.out.println(item)
}
}
}
小结
参考
-
设计模式: 可复用面向对象软件的基础
-
迭代器模式(Iterator)- 指尖飞舞
-
大话设计模式
-
高淇讲设计模式
- by 攻城师@翡青
- Email: feiqing.zjf@gmail.com
- 博客: 攻城师-翡青 - http://blog.csdn.net/zjf280441589
- 微博: 攻城师-翡青 - http://weibo.com/u/3319050953
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)