作用
一般来说,要使用某个类的方法,需要先实例化一个对象再调用方法。但是使用@staticmethod或@classmethod,就可以不需要实例化。
所以@staticmethod或@classmethod作用:使用@staticmethod或@classmethod,就可以不需要实例化,直接类名.方法名()来调用。这有利于组织代码,把某些应该属于某个类的函数给放到那个类里去,同时有利于命名空间的整洁。
区别
既然@staticmethod和@classmethod都可以直接类名.方法名()来调用,那他们有什么区别呢?
从它们的使用上来看:
1、@staticmethod不需要表示自身对象的self和自身类的cls参数,就跟使用函数一样。
2、@classmethod也不需要self参数,但第一个参数需要是表示自身类的cls参数。
3、@classmethod 是一个函数修饰符,它表示接下来的是一个类方法,而对于平常我们见到的则叫做实例方法。类方法的第一个参数cls,而实例方法的第一个参数是self,表示该类的一个实例。
4、类方法有类变量cls传入,从而可以用cls做一些相关的处理。并且有子类继承时,调用该类方法时,传入的类变量cls是子类,而非父类。
5、对于类方法,可以通过类来调用,就像类名.class_foo()
,有点类似C++中的静态方法,也可以通过类的一个实例来调用,就像对象名.class_foo()
6、静态方法基本上跟一个全局函数相同,一般来说用的很少。
7、如果在@staticmethod中要调用到这个类的类属性或类方法,只能直接类名.类属性名
或类名.类方法名
。
8、而@classmethod因为持有cls参数(当然,cls也可以其他单词代替,个人认为是为了和类的self区分才用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)
print(A.bar)
cls().foo()
A.static_foo()
A.class_foo()