새로운 스타일 클래스의 MRO(메소드 해결 순서)
Python에서 MRO(메서드 해결 순서)는 메서드 해결 방법을 결정합니다. 상속의 경우. 새로운 스타일 클래스에서 MRO는 Python in a Nutshell(2판) 문서에 설명된 대로 특정 규칙을 따릅니다.
주어진 예에서 코드는 새로운 스타일 클래스 구문을 사용하지만 MRO는 마치 구식 수업인 것처럼 행동합니다. 새 스타일 클래스에 대해 예상되는 MRO는 이러한 불일치를 수정하기 위해 Base3을 Base1 앞에 배치해야 합니다.
이전 스타일 클래스와 새 스타일 클래스의 MRO 간의 주요 차이점은 동일한 조상이 있을 때 다중 상속을 처리하는 방법에 있습니다. 클래스가 여러 번 나타납니다. 이전 스타일 클래스에서는 깊이 우선 접근 방식으로 인해 메서드가 잘못 해결될 수 있습니다. 그러나 새로운 스타일 클래스에서는 책에 언급된 다이아몬드 상속 패턴이 올바르게 처리됩니다.
예를 들어 다음과 같은 다이아몬드 상속 계층 구조를 고려해보세요.
<code class="python">class A(object): x = 'a' class B(A): pass class C(A): x = 'c' class D(B, C): pass</code>
이전 스타일 클래스에서 , MRO는 D - B - A - C - A가 되며, D의 x 값은 'a'가 됩니다. 그러나 새로운 스타일 클래스에서 MRO는 D - B - C - A - 개체이며, C를 A 앞에 배치하고 C에서 x 재정의가 적용되도록 허용합니다. 이렇게 하면 다이아몬드 상속 문제가 해결됩니다.
따라서 주어진 예에 대한 올바른 MRO는 Derived - Base2 - Base1 - Base3 - 객체이지만 현재 코드는 모호한 MRO 동작으로 인해 잘못된 결과를 생성합니다. 이 문제를 해결하려면 클래스가 개체에서 상속하여 예상 MRO 의미 체계를 호출하도록 명시적으로 지정하도록 클래스 구문을 업데이트해야 합니다.
위 내용은 새로운 스타일 Python 클래스의 MRO가 예상대로 작동하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!