python @classmethod和@staticmethod 装饰器使用
python @classmethod和@staticmethod 装饰器使用
Python其实有3个方法,即静态方法(staticmethod),类方法(classmethod)和实例方法,如下:
def foo(x): print "executing foo(%s)"%(x) class A(object): def foo(self, x): print "executing foo(%s, %s)" % (self, x) @classmethod def class_foo(cls, x): print "executing class_foo(%s, %s)" % (cls, x) @staticmethod def static_foo(x): print "executing static_foo(%s)" % x a = A()
这里先理解下函数参数里面的self和cls,这个self和cls是对类或者实例的绑定。
对于一般的函数来说我们可以这么调用foo(x),这个函数就是最常用的,它的工作跟任何东西(类,实例)无关.
对于实例方法,我们知道在类里每次定义方法的时候都需要绑定这个实例,就是foo(self, x),为什么要这么做呢?因为实例方法的调用离不开实例,我们需要把实例自己传给函数,调用的时候是这样的a.foo(x)(其实是foo(a, x)),对象实例a隐式地作为第一个参数传递:
a.foo(1) # executing foo(<__main__.A object at 0xb7dbef0c>,1)
使用classmethod类方法一样,只不过它传递的是类而不是实例,A.class_foo(x),如果您将某些东西定义为类方法,则可能是因为您打算从类而不是从类实例调用它,注意这里的self和cls可以替换别的参数,但是python的约定是这俩,还是不要改的好。
a.class_foo(1) # executing class_foo(<class '__main__.A'>,1) A.class_foo(1) # executing class_foo(<class '__main__.A'>,1)
使用staticmethods时,self(对象实例)和 cls(类)都不会隐式传递为第一个参数。它们的行为类似于普通函数,不同之处在于您可以从实例或类中调用它们:
a.static_foo(1) # executing static_foo(1) A.static_foo('hi') # executing static_foo(hi)
静态方法常用于对与类之间具有某种逻辑联系的函数进行分组。

浙公网安备 33010602011771号