함수, 바인딩 해제된 메서드, 바인딩된 메서드 간의 차이점 공개
다음 코드 조각을 고려하세요.
<code class="python">class A(object): def f1(self): pass a = A()</code>
변수 f1은 세 가지 별개의 형식으로 나타날 수 있습니다.
객체 구별
def 키워드 또는 람다로 정의된 함수는 클래스 문 내에 배치되면 변환됩니다. Python 2에서 이 변환은 Python 3에는 없는 개념인 바인딩되지 않은 메서드를 생성합니다. 클래스의 인스턴스에서 이 메서드에 액세스하면 인스턴스를 초기 매개변수(self)로 원활하게 바인딩하는 바인딩된 메서드로 변환됩니다.
예:
<code class="python">def f1(self): pass</code>
여기서 f1은 함수입니다. 대조적으로 C.f1은 바인딩되지 않은 메서드입니다.
<code class="python">class C(object): f1 = f1</code>
메서드 호출 및 변환
언바운드 메서드는 인스턴스에서 액세스하여 바인딩된 메서드로 변환될 수 있습니다. 클래스 유형:
<code class="python">C().f1</code>
또는 설명자 프로토콜 사용:
<code class="python">C.f1.__get__(C(), C)</code>
함수는 수동으로 바인딩되지 않은 메서드로 변환할 수 있습니다.
<code class="python">import types types.MethodType(f1, None, C)</code>
이러한 기술을 결합 바인딩된 메서드를 직접 생성할 수 있습니다.
<code class="python">types.MethodType(f1, None, C).__get__(C(), C)</code>
함수와 바인딩되지 않은 메서드 간의 중요한 차이점은 후자의 클래스 바인딩 인식에 있습니다. 따라서 바인딩되지 않은 메서드를 호출하거나 바인딩하려면 관련 클래스 유형의 인스턴스가 필요합니다.
Python 3에서는 함수와 바인딩되지 않은 메서드 간의 구분이 없어집니다. 대신 클래스 인스턴스의 함수에 액세스하면 함수 자체가 직접 반환됩니다.
<code class="python">C.f1 is f1</code>
메소드 동등성
요약하면 다음 호출은 Python 2와 Python 2 모두에서 동일합니다. Python 3:
<code class="python">f1(C()) C.f1(C()) C().f1()</code>
함수를 인스턴스에 바인딩하면 초기 매개변수가 인스턴스에 효과적으로 고정되어 바인딩된 메서드가 다음 람다 식과 유사해집니다.
<code class="python">lambda *args, **kwargs: f1(C(), *args, **kwargs)</code>
위 내용은 Python에서 함수, 바인딩되지 않은 메서드 및 바인딩된 메서드의 차이점은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!