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中文網其他相關文章!