设计模式(十三)——迭代器模式(Iterator)

78 篇文章 0 订阅
23 篇文章 0 订阅
迭代器模式(Iterator)
定义

顺序访问集合对象的元素,不需要知道集合内部的实现,Collection集合中的迭代器就是基于迭代器模式实现

优点
  1. 可以有多个遍历方式
  2. 在迭代器模式中,增加新的聚合类和迭代器类都很方便,无须修改原有代码。
缺点

增加迭代器类会增加代码量

实现

定义一个迭代器,有hasNext方法和next方法

public interface Iterator <E>{
    public boolean hasNext();
    public E next();
}

定义集合,集合中有迭代器

public interface Container {
    public Iterator getIterator();
}

实现集合,同时实现迭代器

public class MyList implements Container{

    String [] names= {"zhangsan","lisi","wangwu","zhaoliu"};

    @Override
    public Iterator getIterator() {
        return new MyIterator();
    }

    private class MyIterator implements Iterator<String>{
        int index=0;
        @Override
        public boolean hasNext() {
            if(index<names.length) {
                return true;
            }
            return false;
        }

        @Override
        public String next() {
            if(hasNext()){
                return names[index++];
            }
            return null;
        }
    }
}

创建迭代器遍历集合

public class Main {
    public static void main(String[] args) {
        MyList myList = new MyList();
        Iterator iterator = myList.getIterator();
        while (iterator.hasNext()){
            System.out.println(iterator.next());
        }
    }
}

运行结果:

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张宜强

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值