zoukankan      html  css  js  c++  java
  • Effective Python Ver2.0_StudyNotes_纯属性与修饰器取代旧式的setter与getter方法

    @property与@{Attribute}.setter的例子

    先看代码,你能读懂吗?

    image

    class Resistor:
        def __init__(self, ohms):
            self.ohms = ohms
    
    class FixedResistance(Resistor):
        def __init__(self, ohms):
            super().__init__(ohms)
    
        @property
        def ohms(self):
            return self._ohms + 1000
    
        @ohms.setter
        def ohms(self, ohms):
            if hasattr(self, '_ohms'):
                raise AttributeError("Ohms is immutable")
            self._ohms = ohms + 1
    
    
    if __name__ == '__main__':
        r4 = FixedResistance(1e3)
        print(r4.ohms)
    

    结果:
    image

    解析:
    r4 = FixedResistance(1e3)实例化时,由于其继承了父类Resistor初始化,所以会触发属性赋值行为(self.ohms = ohms),此时就会触发FixedResistance中定义的@ohms.setter-->
    def ohms(self, ohms)方法,那么self._ohms被赋值为1001,如果继续触发访问属性ohms的行为,则触发@property-->def ohms(self)方法,将则self.ohms的返回结果为1001 + 1000 = 2001.
    image
    image
    image

    当然如果此时,使用实例化对象继续修改_ohms的属性值,那么就会抛异常,报错!
    看到了吗?此行代码可以实现“限制保护属性不被修改”

    总结要点:
    1、如果访问属性时确实有必要做特殊处理,那就通过@property来定义获取属性与设置属性的方法;
    2、实现@property方法时,应该遵循最小惊讶原则,不要引发奇怪的副作用,此方法必须执行得很快。复杂或缓慢的任务,尤其是涉及到I/O或者会引发副作用的任务,还是用普通的方法来实现比较好。
    3、@property最大的缺点是,通过它而编写的属性获取与属性设置方法只能由子类共享。与此无关的类不能共用这份逻辑。但是没关系,Python还支持描述符(descriptor),我们可以利用这种机制把早前编写的属性获取与属性设置逻辑复用到其他许多地方;


    请相信自己

    当我们迷茫,懒惰,退缩的时候 我们会格外的相信命运 相信一切都是命中注定

    而当我们努力拼搏,积极向上时 我们会格外的相信自己

    所以命运是什么呢? 它是如果你习惯它 那它就会一直左右你

    如果你想挣脱它 那它就成为你的阻碍 可如果你打破了它 那它就是你人生的垫脚石!


    如果觉得这篇文章对你有小小的帮助的话,记得在右下角点个“推荐”哦,博主在此感谢!

  • 相关阅读:
    jvm内存溢出问题
    表单提交后台正则表达式验证
    java项目改为web项目
    图片按像素压缩
    系统和压缩内存占用空间大
    teamview修改id
    新浪天气api
    SpringBoot+MySql+Mybatis+ thymeleaf 搭建个人博客
    FFmpeg的简单使用
    禁止f12及浏览器右键查看
  • 原文地址:https://www.cnblogs.com/suguangti/p/15212702.html
Copyright © 2011-2022 走看看