【设计模式】第18节:行为型模式之“迭代器模式”

一、简介

迭代器模式(Iterator Design Pattern),也叫作游标模式(Cursor Design Pattern)。

在通过迭代器来遍历集合元素的同时,增加或者删除集合中的元素,有可能会导致某个元素被重复遍历或遍历不到。有两种比较干脆利索的解决方案,来避免出现这种不可预期的运行结果。一种是遍历的时候不允许增删元素,另一种是增删元素之后让遍历报错。第一种解决方案比较难实现,因为很难确定迭代器使用结束的时间点。第二种解决方案更加合理。

二、优点

  • 抽象性
  • 简化客户端代码
  • 支持多种集合类型
  • 解耦

三、适用场景

  • 遍历不同类型的集合
  • 集合实现可能发生变化
  • 提供一致的遍历接口

四、UML类图

五、案例

遍历书架上的书并打印书名。

go 复制代码
package main

import "fmt"

type Iterator interface {
	HasNext() bool
	Next() interface{}
}

type Book struct {
	Title string
}

func NewBook(title string) *Book {
	return &Book{Title: title}
}

type BookShelf struct {
	BookList []*Book
}

func NewBookShelf() *BookShelf {
	return &BookShelf{BookList: []*Book{}}
}

func (bs *BookShelf) AddBook(book *Book) {
	bs.BookList = append(bs.BookList, book)
}

type BookIterator struct {
	Index     int
	BookShelf *BookShelf
}

func NewBookIterator(bookShelf *BookShelf) *BookIterator {
	return &BookIterator{Index: 0, BookShelf: bookShelf}
}

func (bi *BookIterator) HasNext() bool {
	return bi.Index < len(bi.BookShelf.BookList)
}

func (bi *BookIterator) Next() interface{} {
	if bi.HasNext() {
		book := bi.BookShelf.BookList[bi.Index]
		bi.Index += 1
		return book
	}
	return nil
}

func main() {
	bookShelf := NewBookShelf()
	bookShelf.AddBook(NewBook("book 1"))
	bookShelf.AddBook(NewBook("book 2"))
	bookShelf.AddBook(NewBook("book 3"))

	bookIterator := NewBookIterator(bookShelf)
	for bookIterator.HasNext() {
		bookObj := bookIterator.Next()
		book := bookObj.(*Book)
		fmt.Println(book.Title)
	}
}
相关推荐
明洞日记14 分钟前
【设计模式手册019】状态模式 - 管理对象状态转换
java·设计模式·状态模式
syt_101324 分钟前
设计模式之-发布订阅者模式
设计模式
Yu_Lijing27 分钟前
基于C++的《Head First设计模式》笔记——策略模式
c++·笔记·设计模式
sg_knight30 分钟前
设计模式与代码重构
python·设计模式·重构·开发
好学且牛逼的马1 小时前
HttpServlet 深度拆解:从设计模式看透其核心原理
java·servlet·设计模式
__万波__20 小时前
二十三种设计模式(十三)--模板方法模式
java·设计模式·模板方法模式
⑩-1 天前
Java设计模式-命令模式
java·设计模式·命令模式
AM越.1 天前
Java设计模式超详解--状态设计模式
java·开发语言·设计模式
FreeCode1 天前
智能体设计模式解析:ReAct模式
设计模式·langchain·agent
程序员爱钓鱼1 天前
BlackHole 2ch:macOS无杂音录屏与系统音频采集完整技术指南
前端·后端·设计模式