问题:Python中@staticmethod
和@classmethod
两种装饰器装饰的函数有什么不同?
Python其实有3类方法:
- 静态方法(staticmethod)
- 类方法(classmethod)
- 实例方法(instance method)
看一下下面的示例代码:
1 def foo(x): 2 print "executing foo(%s)" %(x) 3 4 class A(object): 5 def foo(self,x): 6 print "executing foo(%s,%s)" %(self,x) 7 @classmethod 8 def class_foo(cls,x): 9 print "executing class_foo(%s,%s)" %(cls,x) 10 @staticmethod 11 def static_foo(x): 12 print "executing static_foo(%s)" %x 13 14 a = A()
在示例代码中,先理解下函数里面的self和cls。这个self和cls是对类或者实例的绑定,对于一般的函数来说我们可以这么调用foo(x)
,这个函数就是最常用的,它的工作和任何东西(类、实例)无关。对于实例方法,我们知道在类里每次定义方法的时候都需要绑定这个实例,就是foo(self,x)
,为什么要这么做呢?因为实例方法的调用离不开实例,我们需要把实例自己传给函数,调用的时候是这样的a.foo(x)
(其实是foo(a,x)
)。类方法一样,只不过它传递的是类而不是实例,A.class_foo(x)
。注意这里的self和cls可以替换别的参数,但是python的约定是这两个,尽量不要更改。
对于静态方法其实和普通的方法一样,不需要对谁进行绑定,唯一的区别是调用时候需要使用
a.static_foo(x)
或A.static_foo()
来调用.
实例方法 | 类方法 | 静态方法 | |
---|---|---|---|
a = A() | a.foo(x) | a.class_foo(x) | a.static_foo(x) |
A | 不可用 | A.clas_foo(x) | A.static_foo(x) |