Python 3.x의 Super() 마법
Python 3.x에서 super() 함수는 독특한 기능을 자랑합니다. 인수 없이 호출할 수 있습니다. 이 동작은 처음에는 놀랍지만 일반적인 프로그래밍 함정을 해결하기 위해 도입된 의도적인 디자인 선택에서 비롯됩니다.
DRY 위반 및 클래스 이름 모호성 방지
Python 3 이전 .x에서는 다음 코드 조각에 표시된 대로 super()를 호출할 때 클래스의 명시적인 이름 지정이 필요했습니다.
<code class="python">class Foo(Bar): def baz(self): return super(Foo, self).baz() + 42</code>
그러나 이 접근 방식은 DRY 원칙을 위반했으며 다음으로 인한 클래스 이름 모호성에 취약했습니다. 전역 리바인딩 또는 클래스 데코레이터. 이러한 문제를 완화하기 위해 Python 3.x에서는 super()의 마법 구현을 도입했습니다.
런타임 해결을 위해 클래스 셀 활용
현재 super() 구현에서는 class 셀을 사용합니다. 이 셀은 원래 클래스 객체에 대한 액세스를 제공하므로 super()가 명시적인 클래스 이름 지정 없이 런타임 시 슈퍼클래스를 확인할 수 있습니다. 결과적으로 Foo를 다시 할당하더라도 다음 코드는 의도한 대로 작동합니다.
<code class="python">class Foo(Bar): def baz(self): return super().baz() + 42 Spam = Foo Foo = something_else() Spam().baz() # still works</code>
절충 및 구현 세부 정보
처음에는 super()가 다음과 같이 제안되었습니다. 키워드이지만 "너무 마술적"이라는 인식에 대한 우려로 인해 현재 구현이 이루어졌습니다. Guido van Rossum 자신도 super()에 다른 이름을 사용하면 모호할 수 있음을 인식했습니다.
잠재적 단점
super()의 마법 동작은 일반적으로 유익하지만, 슈퍼클래스가 동적으로 수정되거나 super()의 이름이 바뀌면 예상치 못한 결과가 발생할 수 있습니다. 이러한 시나리오에서는 적절한 기능을 보장하기 위해 메서드에서 class 변수를 명시적으로 참조하는 것이 좋습니다.
이름 변경으로 영향을 받는 함수의 대체 예
이름 변경으로 영향을 받을 수 있는 기타 Python 함수 및 메서드는 다음과 같습니다.
위 내용은 `super()`는 인수 없이 Python 3.x에서 어떻게 마법을 작동합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!