Class vs static methods in Python
这篇文章试图解释:什么是staticmethod/classmethod,并且这两者之间的差异.
staticmethod和classmethod均被作为装饰器,用作定义一个函数为”staticmethod”还是”classmethod”
如果想要了解Python装饰器的基础,可以看 这篇文章
Simple, static and class methods
类中最常用到的方法是 实例方法(instance methods), 即,实例对象作为第一个参数传递给函数
例如,下面是一个基本的实例方法
| 123456789101112 | class Kls(object): def __init__(self, data): self.data = data def printd(self): print(self.data) ik1 = Kls(\’arun\’)ik2 = Kls(\’seema\’) ik1.printd()ik2.printd() |
得到的输出:
| 12 | arunseema |
调用关系图:

查看代码和图解:
| 123 | 1/2 参数传递给函数3 self参数指向实例本身 4 我们不需要显式提供实例,解释器本身会处理 |
假如我们想仅实现类之间交互而不是通过实例?我们可以在类之外建立一个简单的函数来实现这个功能,但是将会使代码扩散到类之外,这个可能对未来代码维护带来问题。
例如:
| 12345678910111213 | def get_no_of_instances(cls_obj): return cls_obj.no_inst class Kls(object): no_inst = 0 def __init__(self): Kls.no_inst = Kls.no_inst + 1 ik1 = Kls()ik2 = Kls() print(get_no_of_instances(Kls)) |
结果:
2
The Python @classmethod
现在我们要做的是在类里创建一个函数,这个函数参数是类对象而不是实例对象.
在上面那个实现中,如果要实现不获取实例,需要修改如下:
| 123456789101112131415 | def iget_no_of_instance(ins_obj): return ins_obj.__class__.no_inst class Kls(object): no_inst = 0 def __init__(self): Kls.no_inst = Kls.no_inst + 1 ik1 = Kls()ik2 = Kls()print iget_no_of_instance(ik1) 结果2 |
可以使用Python2.2引入的新特性,使用@classmethod在类代码中创建一个函数
| 123456789101112131415 | class Kls(object): no_inst = 0 def __init__(self): Kls.no_inst = lass=\”crayon-sy\”>(self): Kls.no_inst = ds-in-python\”>Class vs static methods in Python
这篇文章试图解释:什么是staticmethod/classmethod,并且这两者之间的差异. staticmethod和classmethod均被作为装饰器,用作定义一个函数为”staticmethod”还是”classmethod” 如果想要了解Python装饰器的基础,可以看 这篇文章 Simple, static and class methods类中最常用到的方法是 实例方法(instance methods), 即,实例对象作为第一个参数传递给函数 例如,下面是一个基本的实例方法
得到的输出:
调用关系图:
查看代码和图解:
假如我们想仅实现类之间交互而不是通过实例?我们可以在类之外建立一个简单的函数来实现这个功能,但是将会使代码扩散到类之外,这个可能对未来代码维护带来问题。 例如:
结果: 2 The Python @classmethod现在我们要做的是在类里创建一个函数,这个函数参数是类对象而不是实例对象. 在上面那个实现中,如果要实现不获取实例,需要修改如下:
可以使用Python2.2引入的新特性,使用@classmethod在类代码中创建一个函数
|