迭代器模式(Iterator Pattern)

迭代器模式(Iterator Pattern)

定义

又称为游标模式(Cursor Pattern),它提供了一种顺序访问集合/容器对象元素的方法,而又无须暴露集合内部表示。

本质:抽离集合对象迭代行为到迭代器中,提供一致访问接口。

属于行为型模式。

适用场景

  1. 访问一个集合对象的内容而无需暴露它的内部表示
  2. 为遍历不同的集合结构提供一个统一的访问接口

标准示例

  • 迭代器(Iterator):定义访问和遍历元素的接口,通常包含如hasNext()(判断是否有下一个元素)、next()(返回下一个元素)等方法。
  • 具体迭代器(ConcreteIterator):实现迭代器接口,对聚合对象遍历时跟踪当前位置,并能够计算出待遍历的后继对象。
  • 聚合(Aggregate):定义创建相应迭代器对象的接口。
  • 具体聚合(ConcreteAggregate):实现创建相应迭代器的接口,返回一个具体迭代器对象。

代码:

java 复制代码
public interface Iterator<E>{
	boolean hasNext();
	E next();
}
java 复制代码
public class ConcreteIterator<E> implements Iterator<E>{
	private List<E> list;
	private int cursor = 0;
	public ConcreteIterator(List<E> list){
		this.list = list;
	}

	public boolean hasNext(){
		return this.cursor < this.list.size();
	}
		
	public E next(){
		return this.list.get(this.cursor ++);
	}
}
java 复制代码
public interface IAggregate<E>{
	boolean add(E element);
	boolean remove(E element);
	Iterator<E> iterator();
}
java 复制代码
public class ConcreteAggregate<E> implements IAggregate<E>{
	private List<E> list = new Arraylist<E>();
	
	public boolean add(E element){
		return this.list.add(element);
	}
	public boolean remove(E element){
		return this.list.remove(element);
	}
	public Iterator<E> iterator(){
		return new ConcreteIterator<E>(this.list);
	}
}
java 复制代码
public class Test {
    public static void main(String[] args) {
        IAggregate<String> aggregate = new ConcreteAggregate<String>();
        aggregate.add("java");
        aggregate.add("python");
        aggregate.add("javascript");

        Iterator<String> iterator = aggregate.iterator();

        while(iterator.hasNext()){
            String element = iterator.next();
            System.out.println(element);
        }
    }
}

输出结果:

复制代码
java
python
javascript
相关推荐
JAVA面经实录9176 小时前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
许彰午8 小时前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存
Bat U9 小时前
JavaEE|多线程初阶(七)
java·开发语言
掌心向暖RPA自动化11 小时前
如何获取网页某个元素在屏幕可见部分的中心坐标影刀RPA懒加载坐标定位技巧
java·javascript·自动化·rpa·影刀rpa
日取其半万世不竭11 小时前
Minecraft Java版社区服务器搭建教程(Linux,适合新手)
java·linux·服务器
TeamDev12 小时前
JxBrowser 9.0.0 版本发布啦!
java·前端·混合应用·jxbrowser·浏览器控件·跨平台渲染·原声输入
AI人工智能+电脑小能手12 小时前
【大白话说Java面试题】【Java基础篇】第24题:Java面向对象有哪些特征
java·开发语言·后端·面试
geovindu13 小时前
go: Strategy Pattern
开发语言·设计模式·golang·策略模式
AI人工智能+电脑小能手13 小时前
【大白话说Java面试题】【Java基础篇】第25题:JDK1.8的新特性有哪些
java·开发语言·后端·面试
likerhood13 小时前
SLF4J: Failed to load class “StaticLoggerBinder“ 解决
java·log4j·maven