@property @calssmethod @staticmethod

静态属性 == 数据属性
若想方便使用想将类的函数属性同对象的数据属性一样可供对象直接调用,可以在类中的函数前加上装饰器@property,这样就将函数属性
转换为类似数据属性一样可供直接调用(封装)
但是不可被修该(不同于数据属性),静态属性可以访问类的数据属性和实例的数据属性

如果不想通过实例来调用类的函数属性,而直接用类调用函数方法,则这就是类方法,通过内置装饰器@calssmethod
  类名.类方法()
  类方法只是给类使用(无论是否存在实例),只能访问实例属性(变量)

@staticmethod 静态方法只是名义上归属类管理,但是不能使用类变量和实例变量,是类的工具包
放在函数前(该函数不传入self或者cls),所以不能访问类属性和实例属性

class cal:
    cal_name = '计算器'
    def __init__(self,x,y):
        self.x = x
        self.y = y

    @property           #在cal_add函数前加上@property,使得该函数可直接调用,封装起来
    def cal_add(self):
        return self.x + self.y

    @classmethod        #在cal_info函数前加上@classmethon,则该函数变为类方法,该函数只能访问到类的数据属性,不能获取实例的数据属性
    def cal_info(cls):  #python自动传入位置参数cls就是类本身
        print('这是一个%s'%cls.cal_name)   #cls.cal_name调用类自己的数据属性

    @staticmethod       #静态方法 类或实例均可调用
    def cal_test(a,b,c): #改静态方法函数里不传入self 或 cls
        print(a,b,c)

c = cal(10,11)
print(c.cal_name)   #>>> '计算器'   调用类的数据属性
print(c.cal_add)    #>>> 21         这样调用类函数属性看起来跟调用数据属性一样  c.cal_name >>> '计算器'
c.cal_add = 10      #这样修改会报错,因为不可被修改

cal.cal_info()   #>>> '这是一个计算器'
#可以看出上述类并没有实例化,可以通过类直接调用类函数。
当然类方法,实例也可以调用,但是并没有什么用,违反了初衷:类方法就是专门供类使用

c1 = cal(10,11)
cal.cal_test(1,2,3)     #>>> 1 2 3
c1.cal_test(1,2,3)      #>>> 1 2 3
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容