一般来说,要使用某个类的方法,需要先实例化一个对象再调用方法。
而使用@staticmethod或@classmethod,就可以不需要实例化,直接类名.方法名()来调用。
这有利于组织代码,把某些应该属于某个类的函数给放到那个类里去,同时有利于命名空间的整洁。
既然@staticmethod和@classmethod都可以直接类名.方法名()来调用,那他们有什么区别呢
从它们的使用上来看,
如果在@staticmethod中要调用到这个类的一些属性方法,只能直接类名.属性名或类名.方法名。
而@classmethod因为持有cls参数,可以来调用类的属性,类的方法,实例化对象等,避免硬编码。
下面上代码。
class A(object):
bar = 1
def foo(self):
print 'foo'
@staticmethod
def static_foo():
print 'static_foo'
# 调用类自身参数
print A.bar
@classmethod
def class_foo(cls):
print 'class_foo'
#调用类自身参数
print cls.bar
cls().foo()
###执行
A.static_foo()
A.class_foo()
输出
static_foo
1
class_foo
1
foo
普通的方法,第一个参数需要是self,它表示一个具体的实例本身。
如果用了staticmethod,那么类方法就不需要这个self,而将这个方法当成一个普通的函数使用。
而对于classmethod,它的第一个参数不是self,是cls,它表示这个类本身。
class A(object):
def foo1(self):
print "Hello",self
@staticmethod
def foo2():
print "hello"
@classmethod
def foo3(cls):
print "hello",cls
>>> a = A()
# 最常见的调用方式,但与下面的方式相同
>>> a.foo1()
Hello <__main__.A object at 0x9f6abec>
# 这里传入实例a,相当于普通方法的self
# 等同于上面的方法
>>> A.foo1(a)
Hello <__main__.A object at 0x9f6abec>
# 这里,由于静态方法没有参数,故可以不传东西
>>> A.foo2()
hello
# 这里,由于是类方法,因此,它的第一个参数为类本身。
>>> A.foo3()
hello
#可以看到,直接输入A,与上面那种调用返回同样的信息。
# 所以,cls就是类本身。self是类的实例本身
>>> A
参考
https://blog.csdn.net/weixin_41923961/article/details/83097665
https://www.cnblogs.com/chllovegeyuting/archive/2013/03/14/2960532.html