>백엔드 개발 >파이썬 튜토리얼 >Python의 루프 내 람다가 상태를 공유하는 이유는 무엇입니까?

Python의 루프 내 람다가 상태를 공유하는 이유는 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-18 05:53:02306검색

Why Do Lambdas Within Loops in Python Share State?

루프 내의 람다: 공유 상태 주소 지정

Python에서 루프 내에 생성된 람다는 공유 상태로 인해 예기치 않은 동작을 나타낼 수 있습니다. 예를 들어, 객체의 속성에 액세스하는 람다를 생성하는 것을 목표로 하는 다음 코드를 생각해 보세요.

lambdas_list = []
for obj in obj_list:
   lambdas_list.append(lambda : obj.some_var)

그러나 이러한 람다를 반복하고 호출하면 항상 마지막 객체의 속성 값을 얻습니다.

for f in lambdas_list:
    print(f())

이 제한 사항을 해결하기 위해 다음과 같이 간단하게 수정할 수 있습니다.

lambdas_list.append(lambda obj=obj: obj.some_var)

by 람다에 기본 인수를 제공하면 객체 생성 시 객체의 현재 값이 캡처됩니다. 이렇게 하면 각 람다가 자체 상태를 유지하고 원하는 결과를 얻을 수 있습니다.

for f in lambdas_list:
    print(f())

위 내용은 Python의 루프 내 람다가 상태를 공유하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.