你的猜测是正确的-你明白 如何
classmethod的工作。
为什么可以在实例或类上调用这些方法(在两种情况下,类对象都将作为第一个参数传递):
class Dummy(object): @classmethod def some_function(cls,*args,**kwargs): print cls#both of these will have exactly the same effectDummy.some_function()Dummy().some_function()
关于在实例上使用这些方法:在实例上 调用类方法至少有两个主要用途:
self.some_function()
会some_function
根据的实际类型调用的版本self
,而不是该调用恰巧出现的类(如果重命名该类,则无需引起注意);和- 如果
some_function
需要实现某些协议,但仅调用类对象很有用。
与的区别staticmethod
:还有另一种定义不访问实例数据的方法的方法,称为
staticmethod。这样就创建了一个根本不接收隐式第一个参数的方法。因此,将不会传递有关调用它的实例或类的任何信息。
In [6]: class Foo(object): some_static = staticmethod(lambda x: x+1)In [7]: Foo.some_static(1)Out[7]: 2In [8]: Foo().some_static(1)Out[8]: 2In [9]: class Bar(Foo): some_static = staticmethod(lambda x: x*2)In [10]: Bar.some_static(1)Out[10]: 2In [11]: Bar().some_static(1)Out[11]: 2
我发现它的主要用途是将现有函数(不会收到
self)改编为类(或对象)上的方法。



