Go에서 for 루프는 루프 본문 내에서 루프 변수를 변경할 수 없는 C#의 foreach 루프와 다릅니다. Go에서는 루프 변수를 수정할 수 있으므로 캡처된 클로저 동작을 다르게 처리해야 할 필요성이 제기됩니다.
설명하기 위해 세 가지 코드를 살펴보겠습니다. 스니펫:
Lab1:
l := [](func() (int32, int32)){} for k, v := range m { // Closure captures the last values assigned to k and v from the range l = append(l, func() (int32, int32) { return k, v }) }
Lab2:
l := [](func() (int32, int32)){} for k, v := range m { // Closure captures the outer variables k and v (which are modified in the loop) l = append(l, func() (int32, int32) { return k, v }) }
Lab3:
l := [](func() (int32, int32)){} for k, v := range m { kLocal, vLocal := k, v // Captures just the values assigned to k and v at the iteration l = append(l, func() (int32, int32) { return kLocal, vLocal }) }
Lab1 및 Lab2에서 클로저는 루프 본문 내의 루프 변수에 할당된 마지막 값을 캡처합니다. 루프 내에서 루프 변수가 수정되면 잘못된 결과가 발생할 수 있습니다.
Lab3은 올바른 접근 방식을 보여줍니다. 로컬 변수를 사용하여 각 반복 내에서 루프 변수에 할당된 값을 캡처합니다. 이 동작은 캡처된 변수가 기본적으로 참조적으로 투명한 Go의 클로저와 일치합니다.
Go에서 for 루프 변수에 대한 클로저는 참조가 아닌 값을 캡처합니다. 루프 중에 변경될 수 있는 값을 캡처하려면 원하는 값을 클로저에 할당하는 각 반복 내에서 로컬 변수를 생성해야 합니다. 이 접근 방식을 사용하면 폐쇄 동작이 기대치를 충족할 수 있습니다.
위 내용은 Go 클로저는 For 루프 변수를 어떻게 처리하고 예기치 않은 동작을 방지합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!