Go1.23에서는 go1.22에서 실험한 기능인 range-over-func 기능을 가져와서 실제로 사용해볼 수 있습니다. 오랫동안. 그러지 마세요. P'Yod가 읽기 쉽게 설명해드립니다
범위 절이 있는 For 문의 사양부터 3가지 유형의 표현식이 추가되었습니다.
func(func() bool) func(func(V) bool) func(func(K, V) bool)
다음과 같이 설명하기 위해 변수를 하나 추가하고 싶습니다
f func(yield func() bool) f func(yield func(V) bool) f func(yield func(K, V) bool)
사양에는 분노의 표현으로 f 함수를 사용할 때 함수 f를 끝내기 전에 거기에서 항복 함수를 호출할 때마다 각 루프에서 결과를 얻는다고 나와 있습니다. 우리가 수익률에 투입한 가치와 같습니다. 설명할 때에도 여전히 혼란스럽습니다. 코드 작성이 더 좋습니다
func main() { for range loop { fmt.Println("-") } } func loop(yield func() bool) { yield() yield() }
출력:
- -
이와 같은 코드를 작성하면 사양에 따라 f에서 Yield를 2번 호출하기 때문에 2개의 완전한 루프가 생성됩니다. 여기서는 루프 이름을 지정하고 아무 것도 반환하지 않습니다. 어떤 인수도 허용하지 않는 수익률이 있는 패턴을 사용하기로 선택했기 때문입니다
또 다른 예
func main() { for i := range loop { fmt.Println(i) } } func loop(yield func(int) bool) { yield(3) yield(7) }
출력:
3 7
Yield를 한 번 호출했기 때문에 이와 같이 2라운드도 얻게 됩니다. 이제 range는 매번 Yield를 호출하는 데 사용하는 3과 7이라는 2개의 값을 반환합니다.
또 다른 예
func main() { for i := range loop { fmt.Println(i) } } func Loop(yield func(int, string) bool) { yield(3, "three") yield(5, "five") yield(7, "seven") }
출력:
3 three 5 five 7 seven
매번 넣은 수익률에 따라 3개의 루프를 얻고 매번 2개의 값을 얻습니다
그리고
과 같은 모든 유형의 인수를 삽입하여 항복을 호출할 수도 있습니다.
func loop(yield func(string, bool) bool) { yield("three", true) yield("five", false) yield("seven", false) }
이제 메커니즘을 이해했습니다. 어려운 예제를 읽으면 Go Wiki: Rangefunc Experiment
의 예제와 같이 더 많은 것을 이해하게 됩니다.
package slices func Backward[E any](s []E) func(func(int, E) bool) { return func(yield func(int, E) bool) { for i := len(s)-1; i >= 0; i-- { if !yield(i, s[i]) { return } } } }
메인
s := []string{"hello", "world"} for i, x := range slices.Backward(s) { fmt.Println(i, x) }
읽기가 더 쉽죠? 결국, 이를 어떻게 적용할지는 귀하에게 달려 있습니다. 우리는 Yield가 몇 번 호출되는지만 살펴봅니다. 범위 안에 넣어야만 얻을 수 있습니다
나오는 값은 수익률에 들어간 값입니다.
위 내용은 Go의 기능보다 범위의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!