Python.面向对象---静态属性,类方法,静态方法

1,静态属性在函数前加@property,将函数逻辑”封装“成数据属性,外部直接调用函数名,如同调用属性一样。这个函数                      是可以调用对象和类的属性的。
class Room:
    def __init__(self,name,owner,width,length):
        self.name = name
        self.owner = owner
        self.width = width
        self.length = length

    @property
    def cal_area(self):
        return self.length * self.width


r1 = Room('卧室','alex',100,1000)
print(r1.cal_area)

#r1.cal_area = 10   并不是真实的数据属性,所以不可以在外部直接赋值。

2,类方法:在类的方法前添加@classmethod,不需要实例化,直接调用类的该方法。可以访问类的数据属性,但是不可以访                     问对象的数据属性。

class Room:
    style = '别墅'
    def __init__(self,name,owner,width,length):
        self.name = name
        self.owner = owner
        self.width = width
        self.length = length

    @property
    def cal_area(self):
        return self.length * self.width

    @classmethod
    def tell_style(cls):
        #这么写会报错,因为name是对象的数据属性,而类方法是不可以访问实例的属性的
        #print('%s的房间风格是%s'%(cls.name,cls.style))
        print('房间的风格是%s'%(cls.style))


#类方法的定义只是为了类去调用
Room.tell_style()

3,静态方法:在类的方法前加@staticmethod,该方法只是名义上的归属类管理,实例和类的属性均不可以访问,仅仅是类的工                      具包。

class Room:
    style = '别墅'
    def __init__(self,name,owner,width,length):
        self.name = name
        self.owner = owner
        self.width = width
        self.length = length

    @property
    def cal_area(self):
        return self.length * self.width

    @classmethod
    def tell_style(cls):
        #这么写会报错,因为name是对象的数据属性,而类方法是不可以访问实例的属性的
        #print('%s的房间风格是%s'%(cls.name,cls.style))
        print('房间的风格是%s'%(cls.style))

    @staticmethod
    def shower():
        print("洗澡")
    def test(self):
        print("这不是静态方法,而且自动生成参数,必须要有实例")


Room.shower()
r1 = Room('别墅','alex',10,10)
r1.shower()   #这么调用也没有问题

#报错,因为不是静态方法,必须要实例化
Room.test()




猜你喜欢

转载自blog.csdn.net/qq_33531400/article/details/79879165