Python의 @staticmethod 데코레이터와 @classmethod 데코레이터의 차이점 이해
Python의 @staticmethod 및 @classmethod 데코레이터를 사용하면 클래스를 생성할 수 있습니다. 다양한 동작을 가진 레벨 메소드. 주요 차이점에 대한 자세한 설명은 다음과 같습니다.
호출 규칙:
메서드 서명:
인스턴스화:
실제 예:
다음을 고려하세요. 다음 코드 조각:
class A(object): def foo(self, x): print("executing foo({self}, {x})") @classmethod def class_foo(cls, x): print("executing class_foo({cls}, {x})") @staticmethod def static_foo(x): print("executing static_foo({x})") a = A()
foo를 호출할 때 인스턴스 a는 암시적으로 첫 번째 인수로 전달됨:
a.foo(1) # executing foo(<__main__.A object at 0xb7dbef0c>, 1)
클래스 메서드를 사용하면 self 대신 인스턴스의 클래스가 암시적으로 전달됩니다.
a.class_foo(1) # executing class_foo(<class '__main__.A'>, 1)
정적 메서드는 암시적 인수를 받지 않습니다. 인수:
a.static_foo(1) # executing static_foo(1)
요약:
위 내용은 Python에서 `@staticmethod`와 `@classmethod`의 차이점은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!