Go 语言通过闭包、函数类型和接口模拟迭代器模式,支持切片等结构的顺序访问;可定义统一 Iterator 接口实现多集合类型扩展;还可结合 goroutine 与 channel 实现并发安全的异步迭代。
在 Go 语言中,没有内置的迭代器接口(如 Java 的 Iterator 或 Python 的 __iter__),但可以通过函数式风格、闭包和接口轻松模拟迭代器模式,实现对集合元素的顺序访问。
最简洁的方式是让集合类型提供一个返回“下一个元素”函数的方法。该函数内部维护索引或游标状态,每次调用返回当前元素并推进位置。
type NextFunc func() (interface{}, bool),返回元素和是否还有下一项Iterator() 方法,返回一个闭包,捕获原始数据和当前索引
应元素,超出则返回零值和 false
示例(切片迭代器):
func (s SliceCollection) Iterator() func() (int, bool) {
i := -1
return func() (int, bool) {
i++
if i >= len(s.data) {
return 0, false
}
return s.data[i], true
}
}
为支持多种集合类型(数组、链表、树、文件行等),可定义标准迭代器接口,增强可扩展性与组合能力。
type Iterator interface { Next() (interface{}, bool) },隐藏具体实现细节sliceIterator、fileLineIterator)Iterator 接口,不关心底层数据结构这样可复用遍历逻辑,比如写一个通用的 ForEach 函数:
func ForEach(it Iterator, f func(interface{})) {
for v, ok := it.Next(); ok; v, ok = it.Next() {
f(v)
}
}
当需要异步生成元素(如读取大文件、网络流、数据库游标),可用 goroutine + channel 模拟“拉取式”迭代器。
func (c *FileReader) Iterator()
for line := range it.Iterator() 安全消费,无需手动管理状态注意:channel 迭代无法回退或重置,适合一次性、流式场景;若需多次遍历,应保留原始数据源。
Next() 应立即返回 false,而非 panic 或阻塞[]string),优先使用泛型(Go 1.18+)提升类型安全,避免 interface{} 类型断言