本文主要是介绍【Python】@staticmethod和@classmethod的用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
一般来说,要使用某个类的方法,需要先实例化一个对象再调用方法。
而使用@staticmethod或@classmethod,就可以不需要实例化,直接类名.方法名()来调用。
这有利于组织代码,把某些应该属于某个类的函数给放到那个类里去,同时有利于命名空间的整洁。
既然@staticmethod和@classmethod都可以直接类名.方法名()来调用,那他们有什么区别呢
从它们的使用上来看,
- @staticmethod不需要表示自身对象的self和自身类的cls参数,就跟使用函数一样。
-
@classmethod也不需要self参数,但第一个参数需要是表示自身类的cls参数。
如果在@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
继承与覆盖普通类函数是一样的,功能也相同。
问题:
(1)@staticmethod修饰的方法函数与普通的类外函数,为什么不直接使用普通函数?
@staticmethod是把函数嵌入到类中的一种方式,函数就属于类,同时表明函数不需要访问这个类。通过子类的继承覆盖,能更好的组织代码。
(2)这两个方法具体在什么情况下会用到?
如果现在我们想写一些仅仅与类交互而不是和实例交互的方法,使用@classmethod;
class Kls(object):no_inst = 0def __init__(self):Kls.no_inst = Kls.no_inst + 1@classmethoddef get_no_of_instance(cls_obj):return cls_obj.no_inst ik1 = Kls() ik2 = Kls() print ik1.get_no_of_instance() print Kls.get_no_of_instance()输出: 2 2
当出现全局参数配置时,使用@staticmethod,因为他不需要实例化,也没有self参数,不必顾及类中的具体情况,能直接使用。
IND = 'ON' class Kls(object):def __init__(self, data):self.data = data@staticmethoddef checkind():return (IND == 'ON')def do_reset(self):if self.checkind():print('Reset done for:', self.data)def set_db(self):if self.checkind():self.db = 'New db connection'print('DB connection made for: ', self.data) ik1 = Kls(12) ik1.do_reset() ik1.set_db()输出: Reset done for: 12 DB connection made for: 12
这篇关于【Python】@staticmethod和@classmethod的用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!