码迷,mamicode.com
首页 > 编程语言 > 详细

迭代器模式(java版)

时间:2018-12-14 19:25:19      阅读:169      评论:0      收藏:0      [点我收藏+]

标签:用户   java   表示   聚合   item   游标   class   imp   obj   

迭代器模式的组成部分

Aggregate(抽象聚合类)

它用于存储和管理元素对象,声明一个createiterator()方法用于创建一个迭代器对象,充当抽象迭代器工厂角色。

 

ConcreteAggregate(具体聚合类)

它用于抽象聚合类的子类,实现了在抽象集合类中的声明的createIterator()方法,该方法返回一个与该具体聚合类对应的具体迭代器ConcreteIterator实例。

Iterator

它定义了访问和遍历元素的接口,声明了用户遍历数据元素的方法。

first()://用于获取第一个元素

next();//用于访问下一个元素

hasnext();//用于判断是否还有下一个元素

currentitem();//用于获取当前元素

ConcreteIterator

它实现了抽象迭代器接口,完成了对聚合对象的遍历,同时在具体迭代器中通过游标访问来标记在聚合对象中所处的当前位置,在具体实现时,游标通常是一个表示位置的非负整数。

 

 

代码如下:

package com.china.wanson;

public interface Iterator {
public boolean hasNext();
public Object next();

}


package com.china.wanson;

public interface List {
public void add(Object object);
public Object get(int index);
public Iterator interator();
public int getSize();

}

package com.china.wanson;

public class ConcreteAggregate implements List{

private Object[] list;
private int size=0;
private int index=0;


public void add(Object object) {
list[index++]=object;
size++;
}

public Object get(int index) {

return list[index];
}

public Iterator interator() {

return new ConcreteIterator(this);
}

public int getSize() {
return size;
}
}



package com.china.wanson;



public class ConcreteIterator implements Iterator {
private List list=null;
private int index;

public ConcreteIterator(List list){
super();
this.list=list;
}

public boolean hasNext() {
if(index>=list.getSize()){
return false;
}else{
return true;
}
}

public Object next() {
Object object=list.get(index++);
return object;
}
}

迭代器模式(java版)

标签:用户   java   表示   聚合   item   游标   class   imp   obj   

原文地址:https://www.cnblogs.com/wq-9/p/10120668.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!