设计模式(15):迭代器模式

介绍

  • 提供一中可以遍历聚合对象的方式。又称为: 游标cursor模式

迭代器模式角色

  • 抽象聚合类(Aggregate):提供了聚合相关的方法,并提供获取迭代器的方法;
  • 具体集合类(ConcreteAggregate):实现了抽象聚合类;
  • 抽象迭代器(Iterator):定义了迭代相关的方法;
  • 具体迭代器(ConcreteIterator): 实现了抽象迭代器的方法。

场景:

  • 需要以一种特定的方式遍历聚合对象;
  • 聚合对象:存储数据
  • 迭代器:遍历数据

开发中常见的场景

  • JDK内置的迭代器(List/Set)

代码实现

  • 抽象聚合类
java 复制代码
/**
 * 抽象聚合类
 */
public interface Aggregate {
	/**
	 * 添加对象
	 * @param obj
	 */
	void addObject(Object obj);
	/**
	 * 移除对象
	 * @param obj
	 */
	void removeObject(Object obj);
	/**
	 * 获取迭代器方法
	 * @return
	 */
	MyIterator iterator();
}
  • 抽象迭代器
java 复制代码
/**
 *	抽象迭代器
 */
public interface MyIterator {
	/**
	 * 当前游标置零
	 */
	void first(); 
	/**
	 * 将游标指向下一个元素
	 */
	void next();	
	/**
	 * 是否存在下一个元素
	 * @return
	 */
	boolean HasNext();  
	/**
	 * 判断当前对象是否第一个元素
	 * @return
	 */
	boolean isfirst();	
	/**
	 * 判断当前对象是否最后一个元素
	 * @return
	 */
	boolean isLast();		
	/**
	 * 获取当期游标对象
	 * @return
	 */
	Object getCurrentObj();	
}
  • 具体聚合类,内部类方法定义具体迭代器
java 复制代码
public class ConcreteAggregate implements Aggregate {
	private List<Object> list = new ArrayList<Object>();
	/**
	 * 添加对象
	 * @param obj
	 */
	@Override
	public void addObject(Object obj){
		list.add(obj);
	}
	/**
	 * 移除对象
	 * @param obj
	 */
	@Override
	public void removeObject(Object obj){
		list.remove(obj);
	}	
	/**
	 * 获取迭代器方法
	 * @return
	 */
	@Override
	public MyIterator iterator() {
		return new ConcreteIterator();
	} 
	/**
	 * 使用内部类定义迭代器,可以直接使用外部类的属性
	 */
	private class ConcreteIterator implements MyIterator{
		 /**
		  * 定义游标---用于记录遍历List容器时的位置
		  */
		private int cursor; 
		/**
		 * 当前游标置零
		 */
		@Override
		public void first() {
			cursor=0;
		}
		/**
		 * 获取当期游标对象
		 */
		@Override
		public Object getCurrentObj() {
			return list.get(cursor);
		}	
		/**
		 * 将游标指向下一个元素
		 */
		@Override
		public void next() {
			if(cursor<list.size()){
				cursor++;
			}
		}
		/**
		 * 是否存在下一个元素
		 */
		@Override
		public boolean HasNext() {
			if(cursor<list.size()){
				return true;
			}
			return false;
		}
		/**
		 * 判断当前对象是否第一个元素
		 */
		@Override
		public boolean isfirst() {
			return cursor==0?true:false;
		}
		/**
		 * 判断当前对象是否最后一个元素
		 */
		@Override
		public boolean isLast() {
			return cursor==(list.size()-1)?true:false;
		}
	}
}
  • 测试调用
java 复制代码
public static void main(String[] args) {
		Aggregate cma = new ConcreteMyAggregate();
		cma.addObject("aaa");
		cma.addObject("bbb");
		cma.addObject("ccc");
		MyIterator iterator=cma.iterator();
		while(iterator.HasNext()){
			System.out.println(iterator.getCurrentObj());
			iterator.next();
		}
		System.out.println("----------------------------------");
		cma.removeObject("bbb");
		MyIterator iter=cma.iterator();
		while(iter.HasNext()){
			System.out.println(iter.getCurrentObj());
			iter.next();
		}
	}

更多设计模式学习:

设计模式(1):介绍

设计模式(2):单例模式

设计模式(3):工厂模式

设计模式(4):建造者模式

设计模式(5):原型模式

设计模式(6):桥接模式

设计模式(7):装饰器模式

设计模式(8):组合模式

设计模式(9):外观模式

设计模式(10):享元模式

设计模式(11):适配器模式

设计模式(12):代理模式

设计模式(13):模板方法模式

设计模式(14):命令模式

设计模式持续更新中...

相关推荐
Niuguangshuo5 分钟前
Python 设计模式:迭代模式
java·python·设计模式
1ven10 分钟前
JDBC驱动包的隔离加载与卸载
java
Richard201217 分钟前
Java 源码 - Atomic包中的原子操作类总结
java
Richard20121 小时前
Java 源码 - 本地变量ThreadLocal
java·面试
码哝小鱼1 小时前
docker swarm常用命令
java·docker·eureka
不辉放弃1 小时前
Kafka 和 Flink的讲解
java·c#·linq
莫魂魂1 小时前
002_IDEA企业开发工具
java·ide·intellij-idea
〆、风神2 小时前
EasyExcel 数据字典转换器实战:注解驱动设计
android·java·注解
Thanwind2 小时前
关于JVM和OS中的指令重排以及JIT优化
java·jvm·jmm
点燃大海2 小时前
MySQL表结构导出(Excel)
java·数据库·python·mysql·spring