Python中,关于@property装饰器

1.为什么使用@property装饰器?在类中,当我么不想在外界直接调用到类的属性,或者不想展示属性的真实内容时,可以用到@property。
br/>在类中,当我么不想在外界直接调用到类的属性,或者不想展示属性的真实内容时,可以用到@property。

站在用户的角度思考问题,与客户深入沟通,找到亳州网站设计与亳州网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:做网站、网站建设、企业官网、英文网站、手机端网站、网站推广、国际域名空间、虚拟空间、企业邮箱。业务覆盖亳州地区。

2.我们为什么不使用特定的方法来进行上面的操作?
原因是因为太繁琐。例:

class Person:
    def __init__(self, username, password) -> None:
        self.username = username
        self.__password = password

    def get_password(self):
        return self.__password

    def set_password(self, password):
        self.__password = password

p = Person("大狗", "123456")
print(p.get_password())

我们通过声明特别的方法来管理我们队属性的获取与设置,但在外界调用时会凸显出这是一个方法,而不是一个属性,这违背了我们想要隐匿属性的初衷,并且显得很繁琐。
3.当我们不想让调用者通过对象名.属性直接获取属性时,就可以使用@perproty装饰器。例:

class Person:
    def __init__(self, username, password) -> None:
        self.username = username
        self.__password = password

    @property
    def password(self):
        return self.__password

    @password.setter
    def password(self, password):
        self.__password = password

p = Person("大狗", "123456")
print(p.password)

定义属性的同名方法(不要设置成私有方法(__password()),这样会和属性名完全一致,在类内部会出现超出最大递归深度的错误,这是一个大坑...
在用@property装饰器装饰一个方法后,@property会自动设置一个@方法名.stetter的装饰器,用来帮助我们设置属性,如上代码所示。我们可以测试一下

class Person:
    def __init__(self, username, password) -> None:
        self.username = username
        self.__password = password

    @property
    def password(self):
        print(" in @property")
        return self.__password

    @password.setter
    def password(self, password):
        print("in setter")
        self.__password = password

p = Person("大狗", "123456")
print(p.password)
p.password = "654321"
print(p.password)

输出:

in @property
123456
in setter
in @property
654321

可以看到,我们不管用对象名.属性的方法设置属性或者获取属性都是通过调用相对应的方法来进行处理,这样在外部调用者就不知道时真的调用的属性还是方法,很好的隐匿可保护了我们的属性。在属性方法中我们还可以做一些特别的操作。例:

class Person:
    def __init__(self, username, password) -> None:
        self.username = username
        self.__password = password

    @property
    def password(self):
        # print(" in @property")
        return "该属性不对外展示"

    @password.setter
    def password(self, password):
        # print("in setter")
        self.__password = "加密后的:" + password

p = Person("大狗", "123456")
print(p.password)
p.password = "654321"
print(p.__dict__)

输出:

该属性不对外展示
{'username': '大狗', '_Person__password': '加密后的:654321'}

我们不对外展示密码,只进行密码的加密存储。这样就很好的保护了该属性。
欢迎留言。


名称栏目:Python中,关于@property装饰器
网页地址:http://bzwzjz.com/article/gjdogh.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 攀枝花网站设计 成都商城网站建设 网站建设 网站建设方案 网站建设费用 成都品牌网站建设 达州网站设计 定制级高端网站建设 成都网站设计 网站设计 成都网站建设 重庆企业网站建设 重庆网站制作 成都网站制作 成都网站制作 成都网站设计 响应式网站设计方案 成都网站建设 营销型网站建设 成都营销网站建设 重庆网站建设 外贸网站设计方案