今天在Stackoverflow上看见有人提问
What is the difference between @staticmethod and @classmethod in Python?
。有个回答特别好,在此做个笔记。
问题源链接为:http://stackoverflow.com/questions/136097/what-is-the-difference-between-staticmethod-and-classmethod-in-python
概念是枯燥的,作者通过实例来解释,很好的说明了问题。一起来学习下:
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
if __name__ == '__main__':
a = A()
注意 foo,class_foo和static_foo的调用签名的区别
以下是对象实例调用方法的通常方式。 对象实例a作为第一个参数被隐式传递。
a.foo(1)
# executing foo(<__main__.A object at 0x7fe2c6e4e290>, 1)
对于类方法而言,对象实例所属的类被隐式地作为第一个参数传递,而不是self
(对象实例)。
a.class_foo(1)
# executing class_foo(<class '__main__.A'>, 1)
你也可以直接使用类名调用class_foo
。事实上,如果你把一个方法定义成类方法,那可能是因为你打算从类中调用他而不是通过类的实例。A.foo(1)
将会抛出一个TypeError的错误,但是A.class_foo(1)
会运行的很好:
A.class_foo(1)
# executing class_foo(<class '__main__.A'>, 1)
对于静态方法而言,既不是self(对象实例)
,也不是cls(类本身)
作为第一个参数被隐式传递。它们的行为类似于纯函数。你可以通过类或者实例去调用他们。
a.static_foo(1)
# executing static_foo(1)
A.static_foo('hi')
# executing static_foo(hi)
静态方法用于将具有与类的某些逻辑连接的函数分组到该类(或许这个方法与类的关系不大,但从逻辑上来说却属于这个类,把这样的方法移动到类中,也有利于代码的组织)