Go 中是否有惯用的迭代器实现?
通道,让人想起迭代器,通过 range 关键字提供迭代。然而,无法在不产生 goroutine 泄漏的情况下打破这种循环限制了它们的实用性。为了寻求更惯用的迭代器模式,开发人员提出了如何使用映射、过滤器和归约等运算符来表达迭代和组合迭代器的问题。
基于闭包的方法
尽管渠道很方便,但封闭通常被证明更合适。闭包允许创建以顺序方式生成值的迭代器。下面是使用闭包为偶数创建迭代器的示例:
func newEven() func() int { n := 0 return func() int { n += 2 return n } }
基于方法的方法
如果闭包不符合您的喜好,您可以使用带有方法的命名类型:
type even int func (e *even) next() int { *e += 2 return int(*e) }
权衡和链接
闭包和方法之间的选择涉及权衡。闭包更加灵活,而方法提供了更明确的结构。
由于函数的一流性质,Go 中的链接非常简单。以下示例演示了如何将偶数生成器与平方函数链接起来:
func mapInt(g intGen, f func(int) int) intGen { return func() int { return f(g()) } } func square(i int) int { return i * i }
以上是如何在 Go 中惯用地实现迭代器?的详细内容。更多信息请关注PHP中文网其他相关文章!