迭代器模式(四):使用内部类实现迭代器
来源:互联网 发布:ubuntu的apache服务器 编辑:程序博客网 时间:2024/06/12 23:14
4 使用内部类实现迭代器
在迭代器模式结构图中,我们可以看到具体迭代器类和具体聚合类之间存在双重关系,其中一个关系为关联关系,在具体迭代器中需要维持一个对具体聚合对象的引用,该关联关系的目的是访问存储在聚合对象中的数据,以便迭代器能够对这些数据进行遍历操作。
除了使用关联关系外,为了能够让迭代器可以访问到聚合对象中的数据,我们还可以将迭代器类设计为聚合类的内部类,JDK中的迭代器类就是通过这种方法来实现的,如下AbstractList类代码片段所示:
- package java.util;
- ……
- public abstract class AbstractList<E> extends AbstractCollection<E> implements List<E> {
- ......
- private class Itr implements Iterator<E> {
- int cursor = 0;
- ......
- }
- ……
- }
我们可以通过类似的方法来设计第3节中的ProductList类,将ProductIterator类作为ProductList类的内部类,代码如下所示:
- //商品数据类:具体聚合类
- class ProductList extends AbstractObjectList {
- public ProductList(List products) {
- super(products);
- }
- public AbstractIterator createIterator() {
- return new ProductIterator();
- }
- //商品迭代器:具体迭代器,内部类实现
- private class ProductIterator implements AbstractIterator {
- private int cursor1;
- private int cursor2;
- public ProductIterator() {
- cursor1 = 0;
- cursor2 = objects.size() -1;
- }
- public void next() {
- if(cursor1 < objects.size()) {
- cursor1++;
- }
- }
- public boolean isLast() {
- return (cursor1 == objects.size());
- }
- public void previous() {
- if(cursor2 > -1) {
- cursor2--;
- }
- }
- public boolean isFirst() {
- return (cursor2 == -1);
- }
- public Object getNextItem() {
- return objects.get(cursor1);
- }
- public Object getPreviousItem() {
- return objects.get(cursor2);
- }
- }
- }
无论使用哪种实现机制,客户端代码都是一样的,也就是说客户端无须关心具体迭代器对象的创建细节,只需通过调用工厂方法createIterator()即可得到一个可用的迭代器对象,这也是使用工厂方法模式的好处,通过工厂来封装对象的创建过程,简化了客户端的调用。
【作者:刘伟 http://blog.csdn.net/lovelion】
0 0
- 迭代器模式(四):使用内部类实现迭代器
- 内部类+迭代器模式
- 内部类+迭代器设计模式的java实现。。。
- 迭代器的内部类实现
- 使用静态内部类实现延迟加载单例模式
- 使用静态内部类实现单例模式
- “迭代器”设计模式与内部类
- 单例模式——静态内部类实现(推荐使用)
- 内部类的四种实现方式
- 再说说单例模式和多线程(静态内部类实现)
- 单例模式的另一种实现(内部类)
- 2、单例模式(内部类的实现方式)
- Java内部类(四)静态内部类
- 内部类实现单例模式
- 静态内部类实现单例模式
- 单例模式-Singleton Pattern 确保对象的唯一性——单例模式 (四):一种更好的单例实现方法(静态内部类)
- 最安全的单例模式--java使用内部类实现单例模式
- 最安全的单例模式--java使用内部类实现单例模式
- Manifest属性之sharedUserId、sharedUserLabel
- LeetCode database 之 Duplicate Emails(重复的电子邮件)
- 编写一个方法,找出给定字符串的位置。
- 用PHP输出对称菱形的简易办法
- hihocoder1041
- 迭代器模式(四):使用内部类实现迭代器
- hdu 5023 A Corrupt Mayor's Performance Art(线段树区间合并)
- Brief overview of backward and forward
- intent.putExtra()方法参数详解
- Linux多进程
- 一个ACM渣渣关于找工作的胡扯
- JavaScript-初探
- void*相关小知识点
- PAT训练(5)