>백엔드 개발 >파이썬 튜토리얼 >새로운 스타일 Python 클래스의 MRO가 예상대로 작동하지 않는 이유는 무엇입니까?

새로운 스타일 Python 클래스의 MRO가 예상대로 작동하지 않는 이유는 무엇입니까?

DDD
DDD원래의
2024-11-03 22:42:02737검색

Why Does the MRO in My New-Style Python Class Not Behave as Expected?

새로운 스타일 클래스의 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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