1、@staticmethod和@classmethod区别
@staticmethod:静态方法
@classmethod:类方法
一般来说,要使用某个类的方法,需要先实例化一个对象再调用方法。
而使用@staticmethod
或@classmethod
,就可以不需要实例化,直接通过类名就可以实现调用
使用:直接类名.方法名()
来调用。@staticmethod
和@classmethod
都可以直接类名.方法名()
来调用,
@staticmethod
不需要表示自身对象的self
和自身类的cls
参数(这两个参数都不需要添加),就跟使用函数一样。
使用:直接类名.属性名
或直接类名.方法名
。
@classmethod
也不需要self
参数,但第一个参数需要是表示自身类的cls
参数。
使用:直接类名.属性名
或直接类名.方法名
。
两者定义的装饰器调用方法一样,但是@classmethod
装饰器定义的类方法需要传入类参数cls
。
@staticmethod
中要调用到这个类的一些属性方法,只能直接类名.属性名
或类名.方法名
。
而@classmethod
有cls
参数,可以来调用类的属性,类的方法,实例化对象等,避免硬编码更灵活。
2、@staticmethod和@classmethod使用示例代码
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()#通过实例调用方法,对象实例a作为第一个参数隐式传递。a.foo (1)# executing foo(<__main__.A object at 0xb7dbef0c>,1)#对于类方法,对象实例的类将隐式地作为第一个参数而不是传递selfa.class_foo(1)# executing class_foo(,1)#使用这个类调用class_fooA.class_foo(1)# executing class_foo( ,1)#对于staticmethods,self(对象实例)和cls(类)都不会作为第一个参数隐式传递。它们的行为类似普通函数,除了你可以从实例或类中调用它们a.static_foo(1)# executing static_foo(1)A.static_foo('hi')# executing static_foo(hi)print(a.foo)# >print(a.class_foo)# >print(a.static_foo)# print(a.static_foo)#