读设计模式之禅--迭代器模式

  • 定义:它提供一种方法访问一个容器对象中各个元素,而又不需暴露该对象的内部细节。
  • 如果你是做Java开发,尽量不要自己写迭代器模式!省省吧,使用Java提供的Iterator一般就能满足你的要求了,迭代器现在应用得越来越广泛了,甚至已经成为一个最基础的工具。一些大师级人物甚
    至建议把迭代器模式从23个模式中删除,为什么呢?就是因为现在它太普通了,已经融入到各个语言和工具中了。
package design.iterator;

import java.util.Vector;

/**
 * @Author: hyh
 * @Date: 2021/8/21 15:11
 * 抽象一个容器
 **/
public interface Container {
    // 容器添加元素
    void add(Object o);

    // 容器删除元素
    boolean remove(Object o);

    AbstractIterator Iterator();
}

// 具体的容器
class ConcreteContainer implements Container {

    private Vector v = new Vector();

    @Override
    public void add(Object o) {
        this.v.add(o);
    }

    @Override
    public boolean remove(Object o) {
        return this.v.remove(o);
    }

    @Override
    public AbstractIterator Iterator() {
        return new ConcreteIterator(this.v);
    }
}

interface AbstractIterator {
    // 下一个元素
    Object next();

    // 是否有下一个元素
    boolean hasNext();

    // 删除当前元素
    boolean remove();

}

class ConcreteIterator implements AbstractIterator {

    private Vector v;
    // 游标
    private int cursor = 0;

    public ConcreteIterator(Vector v) {
        this.v = v;
    }

    @Override
    public Object next() {
        if (this.hasNext()) {
            return this.v.get(this.cursor++);
        }
        return null;
    }

    @Override
    public boolean hasNext() {
        if(this.cursor == this.v.size()){
            return false;
        }
        return true;
    }

    @Override
    public boolean remove() {
        this.v.remove(this.cursor);
        return true;
    }
}

class Test{
    public static void main(String[] args) {
        Container container = new ConcreteContainer();
        container.add("123");
        container.add("456");
        container.add("789");
        // 当然 java 已经提供了Iterator接口 可以不用写AbstractIterator  直接实现Iterator
        //即可 同样的效果
        AbstractIterator iterator = container.Iterator();
        while (iterator.hasNext()){
            String s = iterator.next().toString();
            System.out.println(s);
        }

    }
}
输出:
123
456
789
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值