Go에서 반복자 생성: 채널 vs. 클로저 vs. 명명된 유형
Go에서는 반복자를 생성하는 다양한 접근 방식이 있습니다. 널리 사용되는 옵션 중 하나는 반복자와 유사한 채널을 활용하는 것입니다. 그러나 채널은 특히 풀 모델이 아닌 푸시 모델이라는 한계로 인해 누출 가능성이 있습니다.
관용적인 접근 방식에는 클로저를 사용하는 것이 포함됩니다. 다음 예에서는 짝수 생성을 위한 반복자를 생성하는 방법을 보여줍니다.
package main import "fmt" func main() { gen := newEven() fmt.Println(gen()) fmt.Println(gen()) fmt.Println(gen()) gen = nil // release for garbage collection } func newEven() func() int { n := 0 return func() int { n += 2 return n } }
또 다른 옵션은 메서드와 함께 명명된 유형을 사용하는 것입니다.
package main import "fmt" func main() { gen := even(0) fmt.Println(gen.next()) fmt.Println(gen.next()) fmt.Println(gen.next()) } type even int func (e *even) next() int { *e += 2 return int(*e) }
클로저와 명명된 유형 사이의 선택은 다음에 따라 다릅니다. 특정 요구 사항. 클로저는 유연성을 제공하는 반면 명명된 유형은 보다 구조화된 접근 방식을 제공할 수 있습니다.
또한 함수가 일급 객체이기 때문에 Go에서는 반복자를 연결하는 것이 간단합니다. 다음 예에서는 제곱 함수를 사용하여 짝수 생성기를 연결합니다.
package main import "fmt" func main() { gen := mapInt(newEven(), square) fmt.Println(gen()) fmt.Println(gen()) fmt.Println(gen()) gen = nil // release for garbage collection } type intGen func() int func newEven() intGen { n := 0 return func() int { n += 2 return n } } 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!