루프 내에서 함수 생성: 지연 바인딩 문제 해결
루프 내에서 개별 함수를 정의하려고 할 때 일반적으로 다음과 같은 문제가 발생합니다. 모든 함수는 고유한 결과를 나타내도록 의도되었음에도 불구하고 동일한 값을 반환합니다. 지연 바인딩이라고 하는 이 현상은 함수가 호출될 때까지 인수를 받지 못하기 때문에 발생합니다.
for 루프를 사용하는 다음 예를 고려하세요.
functions = [] for i in range(3): def f(): return i functions.append(f)
작성된 대로 각 함수는 호출될 때 해당 i 값을 찾습니다. 그러나 루프가 실행된 후 모든 함수는 i(2)의 최종 값을 참조하여 다음과 같은 결과를 출력합니다.
print([f() for f in functions]) # Expected: [0, 1, 2] # Actual: [2, 2, 2]
해결책: 조기 바인딩 적용
이 문제를 해결하려면 호출 시간이 아닌 정의 시간에 함수에 인수를 할당하여 조기 바인딩을 강제해야 합니다. 이는 함수 정의에 기본 인수를 추가하여 달성할 수 있습니다.
functions = [] for i in range(3): def f(i=i): return i functions.append(f)
기본 인수(이 경우 i=i)는 함수가 호출될 때가 아니라 함수가 정의될 때 평가됩니다. 이렇게 하면 각 함수가 고유한 인수 값을 유지하여 원하는 출력을 생성할 수 있습니다.
print([f() for f in functions]) # Output: [0, 1, 2]
클로저를 사용한 대체 접근 방식
추가 인수의 가능성이 우려되는 경우 함수에 전달하려면 클로저를 사용하여 보다 정교한 접근 방식을 구현할 수 있습니다.
def make_f(i): def f(): return i return f
여기서 시나리오에서는 함수 팩토리(make_f)가 생성됩니다. 루프 내에서 make_f에서 반환된 함수는 def f():를 직접 호출하는 대신 f 변수에 할당됩니다. 이 접근 방식은 초기 바인딩 솔루션에서처럼 각 함수가 배타적인 인수 값을 유지하도록 보장합니다.
위 내용은 루프에 정의된 함수가 종종 동일한 값을 반환하는 이유는 무엇이며, 이 문제를 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!