새로운 스타일 클래스의 MRO(메서드 결정 순서)
Python의 클래스 기반 프로그래밍 맥락에서 MRO(메서드 결정 순서) )는 클래스의 인스턴스에서 메서드 조회가 수행되는 순서를 정의합니다. MRO의 구현은 이전 스타일 클래스와 새 스타일 클래스에 따라 다릅니다.
이전 스타일 클래스 상속
이전 스타일 클래스에서 MRO는 다음과 같은 깊이를 따릅니다. 첫 번째 접근 방식. 서브클래스의 인스턴스에서 메소드를 검색할 때 인터프리터는 서브클래스의 상속 계층 구조를 깊이 우선으로 탐색합니다. 기본 클래스에서 처음 나타나는 메소드를 반환합니다.
새로운 스타일 클래스 상속
새로운 스타일 클래스의 도입으로 MRO 의미 체계가 C3으로 변경되었습니다. 선형화. 이 접근 방식은 상속 계층 구조에서 동일한 기본 클래스가 여러 번 나타날 때 발생하는 모호성을 제거합니다. 새로운 스타일 클래스의 MRO는 다음과 같이 계산됩니다.
다중 상속의 예
새 스타일 클래스에서 다중 상속과 관련된 다음 예를 고려하세요.
<code class="python">class Base1(object): def amethod(self): print("Base1") class Base2(Base1): pass class Base3(object): def amethod(self): print("Base3") class Derived(Base2, Base3): pass instance = Derived() instance.amethod() print(Derived.__mro__) </code>
이 예에서는 Base1이 상속에서 여러 번 발생하더라도 계층 구조에서 파생의 MRO는 다음과 같습니다.
(<class '__main__.Derived'>, <class '__main__.Base2'>, <class '__main__.Base1'>, <class '__main__.Base3'>, <type 'object'>)
이 순서는 위에서 설명한 C3 선형화 알고리즘에 해당합니다. Derived는 리프 클래스이므로 MRO에서 첫 번째로 배치됩니다. 그런 다음 기본 클래스인 Base2(Base1의 하위 클래스)와 Base3이 순서대로 추가됩니다. 마지막으로 객체가 최종 기본 클래스로 추가됩니다.
결론
새로운 스타일 클래스에 대한 MRO는 메서드 상속을 해결하기 위한 결정적이고 명확한 방법을 제공합니다. 이는 이전 스타일 클래스 상속의 경우처럼 동일한 기본 클래스가 여러 번 발생하여 발생할 수 있는 잠재적인 모호성을 제거합니다.
위 내용은 Python의 MRO(Method Resolution Order)는 어떻게 새로운 스타일 클래스에서 명확한 메서드 상속을 보장합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!