首頁 >後端開發 >Golang >如何在 Go 中慣用地實現迭代器?

如何在 Go 中慣用地實現迭代器?

Patricia Arquette
Patricia Arquette原創
2024-12-02 04:48:13388瀏覽

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