迭代器模式(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
相关推荐
再难也得平9 小时前
微服务拆分之SpringCloud
java·spring cloud·微服务
ypf52089 小时前
springboot DevTools热部署
java
智_永无止境9 小时前
Spring Boot全局异常处理指南
java·spring boot
塔能物联运维9 小时前
物联网边缘节点数据缓存优化与一致性保障技术
java·后端·物联网·spring·缓存
纸巾哥哥9 小时前
大型系统性能优化问题
java·性能优化
悟能不能悟10 小时前
idea运行tomcat的日志文件放到哪里了
java·tomcat·intellij-idea
屹奕10 小时前
基于EasyExcel实现Excel导出功能
java·开发语言·spring boot·excel
吴名氏.10 小时前
细数Java中List的10个坑
java·开发语言·数据结构·list
初学者,亦行者10 小时前
Rayon并行迭代器:原理、实践与性能优化
java·开发语言·spring·rust
毕设源码-赖学姐10 小时前
【开题答辩全过程】以 二手交易系统的设计与实现为例,包含答辩的问题和答案
java·eclipse