什么是迭代器模式
迭代器模式就是可以提供一种可以遍历聚合对象的方式.又称为游标cursor模式.
迭代器的角色构成
- 迭代器角色:定义遍历元素所需要的方法,如获取下一个元素的方法next(),判断是否遍历结束的方法hasNext(),移除当前对象的方法remove().
- 具体迭代器角色:实现迭代器接口中定义的方法,完成集合的迭代
- 容器角色:一般是一个接口,提供一个iterator()方法.如:Java中的Collection接口,List接口,Set接口.
- 具体容器角色:抽象容器的具体实现类.如:List接口有序列表实现ArrayList,List接口的链表实现linkList,Set接口的哈希列表的实现HashSet();
常用于开发正向遍历的迭代器和逆向遍历的迭代器.
正向遍历迭代器案例
自定义迭代器接口:
public interface MyIterator {
void first(); // 将游标指向第一个元素
void next(); // 将游标指标下一个元素
boolean hasNext(); // 判断是否存在下一个元素
boolean isFirst(); // 判断是否为第一个元素
boolean isLast(); // 判断是否为最后一个元素
Object getCurrentObj(); // 获取当前游标指向的对象
}
自定义容器,内部类实现迭代器接口:
public class ConcreteMyAggregate {
private List<Object> list=new ArrayList<Object>();
public ConcreteMyAggregate() {};
public ConcreteMyAggregate(List<Object> list) {
this.list=list;
}
//添加
public void addObject(Object object) {
this.list.add(object);
}
//删除
public void removeObject(Object object) {
this.list.remove(object);
}
//获取
public List<Object> getList(){
return list;
}
//修改
public void setList(List<Object> list) {
this.list=list;
}
//使用内部类定义迭代器,可以直接使用外部类的属性
private class ConreteIterator implements MyIterator{
private int cursor; // 定义游标用于记录遍历时的位置
@Override
public void first() {
// 第一个,设置游标为0
cursor = 0;
}
@Override
public void next() {
// 下一个,判断是否为最后一个数据,如果不是则游标+1
if(cursor<list.size()){
cursor++;
}
}
@Override
public boolean hasNext() {
// 是否存在下一个,判断游标是否小于list的长度,是则存在下一个
if(cursor < list.size()){
return true;
}
return false;
}
@Override
public boolean isFirst() {
// 是否为第一个,判断游标是否为0,是返回true,否则返回false
return cursor == 0 ? true : false;
}
@Override
public boolean isLast() {
// 是否有最后一个,游标等于list的长度,是返回true,否则返回false
return cursor == (list.size()-1) ? true : false;
}
@Override
public Object getCurrentObj() {
// 获取当前游标指向的对象
return list.get(cursor);
}
}
//获取迭代器
public MyIterator createIterator() {
return new ConreteIterator();
}
}
测试代码:
public class Test {
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();
}
}
}