@property装饰器的使用场景
场景一:修饰方法,让方法可以像属性一样被访问。
class A():
def without_property(self):
return 666
@property
def with_property(self):
return 666
#没有加@property , 必须使用正常的调用方法的形式,即在后面加()
# 没有使用property修饰,它是一种方法,如果把括号去掉,不会报错输出的就会是方法存放的地址。
A().method_without_property()
# 加了@property后,可以用调用属性的形式来调用方法,后面不需要加()
# 如果使用property进行修饰后,又在调用的时候,方法后面添加了(), 那么就会显示错误信息:TypeError: 'int' object is not callable
# 也就是说添加@property 后,这个方法就变成了一个属性,如果后面加了(),那么就是当作函数来调用,而它却不是callable(可调用)的。
A().method_with_property
以上两者返回值均为666
场景二:与属性配合使用,防止属性被修改。 通过@property的方法来进行设置。这样可以隐藏属性名,让用户进行使用的时候无法随意修改。 使用条件: 必须和属性名一样
class B():
def __init__(self):
self._name = yaya #定义属性的名称
self._age = 3
@property
def name(self): # 被@property装饰后,这个方法相当于一个属性,这个属性可以让用户进行使用,而且用户有没办法随意修改。
return self._name
@property
def age(self):
return self._age
data = B()
# 加了@property后,可以用调用属性的形式来调用方法,所以后面不需要加()。
# 进行属性调用的时候,直接调用方法名name即可,而不用知道属性名_name,因此用户无法更改属性,从而保护了类的属性。
print(data.name)