List Comprehensions의 예기치 않은 동작: 리바운드 이름과 흐린 범위
Python의 List Comprehensions은 목록을 생성하는 간결하고 편리한 방법을 제공합니다. 그러나 여기에는 숨겨진 함정이 있습니다. 즉, 범위를 넘어서는 이름을 다시 바인딩하는 것입니다. 이해 그 자체. Python 2에서는 이 특이한 동작이 불만과 프로그래밍 오류의 원인이 되었습니다.
다음 코드를 고려하세요.
x = "original value" squares = [x**2 for x in range(5)] print(x) # Prints 4 in Python 2!
Python 2에서 이 코드를 실행하면 예기치 않게 4가 인쇄됩니다. "원래 값." 이는 리스트 컴프리헨션이 루프 제어 변수 x를 주변 범위로 유출하여 원래 값을 재정의하기 때문입니다.
이 동작은 리스트 컴프리헨션이 Python 2에서 효율성을 향상시키기 위한 최적화로 구현된 방식에서 비롯됩니다. 그러나 이는 Python 프로그래머들에게 상당한 고충이 되어 오류와 혼란을 초래했습니다.
다행히 Python 3에서는 이 "더러운 작은 비밀"이 제거되었습니다. 이제 목록 이해는 별도의 실행 프레임을 사용하는 생성기 표현식과 동일한 구현 전략을 채택합니다. 결과적으로 Python 3에서는 컴프리헨션 내의 x가 주변 범위의 x를 가리지 않기 때문에 위의 코드 조각은 예상대로 "원래 값"을 올바르게 인쇄합니다.
Python의 창시자인 Guido van Rossum, 이 변경 이유를 설명했습니다.
"[우리는] 동일한 구현 전략을 사용하여 목록 이해의 '더러운 작은 비밀'을 수정하기 위해 이 변경을 수행했습니다. 생성기 표현식도 마찬가지입니다."
Python 3의 이러한 개선된 동작은 Python 언어의 지속적인 개발과 개선에 대한 증거로, 목록 이해 사용에 있어서 더 큰 명확성과 예측 가능성을 보장합니다.
위 내용은 Python 2의 List Comprehension이 범위 밖의 이름을 다시 바인딩하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!