16、迭代子模式

迭代子模式:迭代子模式可以顺序访问一个聚集中的元素而不必暴露聚集的内部表象。

public interface Collection {      
	public Iterator iterator();  	  
	public Object get(int i); //取得集合元素
	public int size();  //取得集合大小
}  
public interface Iterator {  
	public Object previous();  //前移  
	public Object next();  //后移  
	public boolean hasNext();  
	public Object first(); //取得第一个元素    
}  
public class MyCollection implements Collection {    
	public String string[] = {"A","B","C","D","E"};  
	@Override  
	public Iterator iterator() {  
		return new MyIterator(this);  
	}  
	@Override  
	public Object get(int i) {  
		return string[i];  
	}  
	@Override  
	public int size() {  
		return string.length;  
	}  
}  
public class MyIterator implements Iterator {    
	private Collection collection;  
	private int pos = -1;  
	public MyIterator(Collection collection){  
		this.collection = collection;  
	}  
	@Override  
	public Object previous() {  
		if(pos > 0){  
			pos--;  
		}  
		return collection.get(pos);  
	}  
	@Override  
	public Object next() {  
		if(pos<collection.size()-1){  
			pos++;  
		}  
		return collection.get(pos);  
	}  
  
	@Override  
	public boolean hasNext() {  
		if(pos<collection.size()-1){  
			return true;  
		}else{  
			return false;  
		}  
	}  
	@Override  
	public Object first() {  
		pos = 0;  
		return collection.get(pos);  
	}  
}  
public class Test {  
    public static void main(String[] args) {  
		Collection collection = new MyCollection();  
		Iterator it = collection.iterator();  
		while(it.hasNext()){  
			System.out.println(it.next());  
		}  
	}  
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值