迭代器模式提供一种方法顺序访问一个聚合对象中各个元素,而又不需暴露该对象的内部表示,属于行为模式的一种 bash
优势:ide
缺点:ui
因为迭代器模式将存储数据和遍历数据的职责分离,增长新的聚合类须要对应增长新的迭代器类,类的个数成对增长,这在必定程度上增长了系统的复杂性spa
定义抽象迭代器Iteratorcode
public interface Iterator<T> {
boolean hasNext();
T first();
T next();
}
复制代码
定义具体迭代器FilmMenuIteratorcdn
public class FilmMenuIterator implements Iterator<MenuItem> {
private List<MenuItem> menuItems;
private int position = 0;
public FilmMenuIterator(List<MenuItem> itemList) {
menuItems = itemList;
}
@Override
public boolean hasNext() {
if (position > menuItems.size() - 1 || menuItems.get(position) == null) {
return false;
} else {
return true;
}
}
@Override
public MenuItem first() {
return menuItems.size() > 0 ? menuItems.get(0) : null;
}
@Override
public MenuItem next() {
MenuItem menuItem = menuItems.get(position);
position++;
return menuItem;
}
}
复制代码
定义抽象容器MenuAggregate对象
public interface MenuAggregate<T> {
void addItem(int id, String name);
Iterator<T> create();
}
复制代码
定义具体容器FilmAggregateblog
public class FilmAggregate implements MenuAggregate<MenuItem> {
private List<MenuItem> menuItems;
public FilmAggregate() {
menuItems = new ArrayList<>();
}
@Override
public void addItem(int id, String name) {
menuItems.add(new MenuItem(id, name));
}
@Override
public Iterator<MenuItem> create() {
return new FilmMenuIterator(menuItems);
}
}
复制代码
客户端实现接口
FilmAggregate film = new FilmAggregate();
film.addItem(1, "西红柿首富");
film.addItem(2, "兄弟");
film.addItem(2, "反贪风暴");
Iterator it = film.create();
while(it.hasNext()){
System.out.println(it.next().toString());
}
复制代码