classmethod:类方法
staticmethod:静态方法

在python中,静态方法和类方法都是可以通过类对象类对象实例访问。但是区别是:

staticmethod:静态方法

功能:将被装饰的函数从类中分离出来,该函数不能访问类的属性,简单说可以将该函数理解为一个独立的函数,不允许使用self。

 staticmethod 就是将该被装饰的函数与该类没有关系,该函数不能用self传参,需要和普通函数一样传参。

作用:
限制名称空间,这个函数虽然是个普通的函数,但只有这个类里能用到
代码易读性.静态方法并不需要self参数
约内存.不用每个实例都实例化方法.
在类内部控制静态方法.不然的话换一种实现方法,把函数放在在类外部

 

@classmethod 是一个函数修饰符,它表示接下来的是一个类方法,而对于平常我们见到的则叫做实例方法。 类方法的第一个参数cls,而实例方法的第一个参数是self,表示该类的一个实例。 

普通对象方法至少需要一个self参数,代表类对象实例

类方法有类变量cls传入,从而可以用cls做一些相关的处理。并且有子类继承时,调用该类方法时,传入的类变量cls是子类,而非父类。 对于类方法,可以通过类来调用,就像C.f(),有点类似C++中的静态方法, 也可以通过类的一个实例来调用,就像C().f(),这里C(),写成这样之后它就是类的一个实例了。 

静态方法则没有,它基本上跟一个全局函数相同,一般来说用的很少

#!/usr/bin/env python
# -*- coding: utf-8 -*-
class TClassStatic(object):
    obj_num = 0
    def __init__(self, data):
        self.data = data
        TClassStatic.obj_num += 1
    def printself(self):
        print("self.data: ", self.data)
    @staticmethod
    def smethod():
        print("the number of obj is : ", TClassStatic.obj_num)
    @classmethod
    def cmethod(cls):
        print("cmethod : ", cls.obj_num)
        cls.smethod()
def main():
    objA = TClassStatic(10)
    objB = TClassStatic(12)
    objB.printself()
    objA.smethod()
    objB.cmethod()
    print("------------------------------")
    TClassStatic.smethod()
    TClassStatic.cmethod()
if __name__ == "__main__":
    main()