设计模式之迭代器模式---以JDK源码为例

在访问一些集合类中的对象时,不同的集合类有不同的访问方式,这使得我们访问集合类中的元素很不方便。能不能提供一个统一的方法来访问所有的集合类中的对象,代器模式就是为解决这个问题而诞生的。

在JDK的List等集合类中有iterator()方法,该方法返回一个Iterator类型的对象,其实是在ArrayList类中定义的一个内部类;下面的代码模拟JDK中ArrayList的实现来让大家了解迭代器模式;

迭代器模式的UML类图如下:


在下面的代码中,Sequence类相当于JDK中的ArrayList类,Selector接口相当于JDK中的Iterator接口;

Selector接口中的方法定义如下:

package com.javaInnerClass;

public interface Selector {
	boolean end();
	void next();
	Object current();
}
Sequence类定义如下:

package com.javaInnerClass;

public class Sequence {
	private Object[] items;
	private int i;
	public Sequence(){
	}
	
	public Sequence(int size){
		items = new Object[size];
	}
	
	class SequenceSelector implements Selector{
		private int next;
		@Override
		public boolean end() {
			return (next==items.length);
		}

		@Override
		public void next() {
			// TODO Auto-generated method stub
			next++;
		}

		@Override
		public Object current() {
			// TODO Auto-generated method stub
			return items[next];
		}
		
	}
	
	public void addElement(Object o){
		if(i<items.length)
			items[i++] = o;
	}
	
	public Selector selector(){
		return new SequenceSelector();
	}
	
	
	//测试这个Sequence类的使用情况
	public static void main(String[] args) {
		Sequence seq = new Sequence(10);
		for(int j=0;j<10;j++)
			seq.addElement(String.valueOf(j));
		
		Selector s = seq.selector();
		while(!s.end()){
			System.out.print(s.current()+"  ");
			s.next();
		}
			
		
	}
	
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值