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

78 篇文章 0 订阅
23 篇文章 0 订阅
迭代器模式是一种设计模式,它允许我们遍历集合对象的元素而无需暴露其内部表示。这种模式提供了多种遍历方式,同时对集合类和迭代器类的扩展非常灵活。在Java的Collection框架中,迭代器被广泛使用。MyList类作为示例实现了集合和迭代器,其中MyIterator类实现了迭代器接口,提供hasNext和next方法进行元素访问。在主程序Main中,通过迭代器遍历并打印了集合中的所有元素。
摘要由CSDN通过智能技术生成
迭代器模式(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());
        }
    }
}

运行结果:

在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

张宜强

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

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

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

打赏作者

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

抵扣说明:

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

余额充值