首页 >后端开发 >Golang >如何在 Go 中惯用地实现迭代器?

如何在 Go 中惯用地实现迭代器?

Patricia Arquette
Patricia Arquette原创
2024-12-02 04:48:13462浏览

How Can I Idiomatically Implement Iterators in Go?

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn