(十一)迭代器模式建模与实现
最后更新于:2022-04-01 09:31:22
迭代器模式(Iterator):提供了一种方法顺序访问一个聚合对象中的各个元素,而又不暴露其内部的表示。
##一、uml建模:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-19_56c7196ddb28e.jpg)
##二、代码实现
~~~
/**
* 示例:迭代器模式
*
*/
interface Iterator {
/**前移 */
public Object previous();
/**后移 */
public Object next();
/**判断是否有下一个元素 */
public boolean hasNext();
}
interface Collection {
public Iterator iterator();
/**取得集合中的某个元素 */
public Object get(int i);
/**取得集合大小 */
public int size();
}
/**
* 集合
*/
class MyCollection implements Collection {
private String[] strArray = { "aa", "bb", "cc", "dd" };
@Override
public Iterator iterator() {
return new MyIterator(this);
}
@Override
public Object get(int i) {
return strArray[i];
}
@Override
public int size() {
return strArray.length;
}
}
/**
* 迭代器
*/
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;
}
return false;
}
}
/**
* 客户端测试类
*
* @author Leo
*/
public class Test {
public static void main(String[] args) {
/**
* 实例化容器
*/
Collection collection = new MyCollection();
/**
* 创建迭代器
*/
Iterator iterator = collection.iterator();
/**
* 遍历集合中的元素
*/
while (iterator.hasNext()) {
System.out.println(iterator.next());
}
}
}
~~~
##三、应用场景
遍历、访问集合中的某个元素等
##四、总结
迭代器模式就是顺序访问集合中的对象,这句话包含两层意思:一是需要遍历的对象,即集合对象,二是迭代器对象,用于对集合对象进行遍历访问。