设计模式之迭代器模式

迭代器模式

概述

迭代器模式(Iterator),提供一种方法顺序访问一个聚合对象中的各种元素,而又不暴露该对象的内部表示。

对于Java来说迭代器并不陌生,比如map的遍历就是使用迭代器来实现的。

示例程序

我们模拟将书放在书架上,并且按照顺序显示出来

名字说明
Aggregate表示集合的接口
Iterator遍历集合的接口
Book表示书的类
BookShelf表示书架的类
BookShelfIterator遍历书架的类

UML类图

在这里插入图片描述

代码实现

Aggregate

想要遍历集合中的元素时,可以调用iterator方法来生成Iterator实例

public interface Aggregate {
    Iterator iterator();
}

Iterator

hasNext方法判断集合中是否还有下一个元素,next方法是获取集合中的下一个元素

public interface Iterator {
    boolean hasNext();
    Object next();
}

Book

粗略的写一下Book实体类,在这段程序中并不重要

@Data
@NoArgsConstructor
@AllArgsConstructor
public class Book {
    private String name;
}

BookShelf

BookShelf可以将他看成类似于集合的东西,底层使用数组来存储数据

public class BookShelf implements Aggregate {
    private Book[] books;
    private int last;

    public BookShelf(int maxSize){
        this.books = new Book[maxSize];
    }
	//根据下标获取书
    public Book getBookAt(int index){
        return books[index];
    }
	//添加书籍
    public void appendBook(Book book){
        this.books[last] = book;
        last++;
    }
	//获取集合的长度
    public int getLength(){
        return last;
    }

    @Override
    public Iterator iterator() {
        return new BookShelfIterator(this);
    }
}

BookShelfIterator

BookShelfIterator是核心类,主要实现Iterator接口中的方法

public class BookShelfIterator implements Iterator {
    private BookShelf bookShelf;
    private int index;

    public BookShelfIterator(BookShelf bookShelf) {
        this.bookShelf = bookShelf;
        this.index = 0;
    }

    @Override
    public boolean hasNext() {
        if (index < bookShelf.getLength()){
            return true;
        }
        return false;
    }

    @Override
    public Object next() {
        Book bookAt = bookShelf.getBookAt(index);
        index++;
        return bookAt;
    }
}

Test

@SpringBootTest
class Practice1800ApplicationTests {

    @Test
    void contextLoads() {
        BookShelf bookShelf = new BookShelf(4);
        bookShelf.appendBook(new Book("钢铁是怎样练成的"));
        bookShelf.appendBook(new Book("八十天环游世界"));
        bookShelf.appendBook(new Book("孔乙己"));
        bookShelf.appendBook(new Book("朝花夕拾"));

        Iterator iterator = bookShelf.iterator();
        while (iterator.hasNext()){
            Book book = (Book) iterator.next();
            System.out.println(book);
        }
    }

}

//结果
Book(name=钢铁是怎样练成的)
Book(name=八十天环游世界)
Book(name=孔乙己)
Book(name=朝花夕拾)

登场角色

  • Iterator(迭代器)

    该角色负责定义按顺序逐个遍历元素的接口,在示例程序中由Iterator接口扮演。它定义了两个方法,hasNext判断集合是否遍历完,next返回当前元素,并指向下一个原色

  • ConcreteIterator(具体的迭代器)

    该角色实现了Iterator角色定义的接口,在示例程序中由BookShelfIterator扮演该角色。该角色包含了遍历集合所需要的信息

  • Aggregate(集合)

    该角色负责定义创建Iterator角色的接口。这个接口是一个方法,会创建出按顺序访问保存在内部元素的人。在示例程序中由Aggregate扮演该角色

  • ConcreteAggregate(具体的集合)

    该角色负责实现Aggregate角色所定义的接口。他会创建出Iterator角色。在示例程序中由BookShelf扮演该角色

总结

迭代器模式从以上的功能实现可以看到,满足了单一职责和开闭原则,外界的调用方不需要知道任何一个不同的数据结构在使用上的遍历差异。可以非常方便的扩展,也让整个遍历变得更加干净。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值