@classmethod和@staticmethod
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) | 
                    
                
                
            
        
浙公网安备 33010602011771号