鱼C论坛

 找回密码
 立即注册
查看: 1039|回复: 0

[技术交流] python 045 属性访问

[复制链接]
发表于 2018-7-8 18:06:13 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 风不会停息 于 2018-7-8 18:07 编辑

1. 四种跟属性有关的魔法方法:
        1. __getattr__(self, name): 定义当用户试图获取一个不存在的属性的行为
        2. __getattribute(self, name): 定义当该类的属性被访问时的行为
        3. __setattr__(self, name, value): 定义一个属性被设置时的行为
        4. __delattr__(self, name): 定义一个属性被删除时的行为

2. 重写__setattr__()时应注意无限递归的问题, 例如:
def __setattr__(self, name, value):
        self.name = value + 1

这段代码试图在对象的属性发生赋值操作的时候,将实际的值 +1赋值给相应的属性。但这么写法是错误的,因为每当属性被赋值的时候, __setattr__() 会被调用,而里边的 self.name = value + 1 语句又会再次触发 __setattr__() 调用,导致无限递归。

代码应该这样写:
def __setattr__(self, name, value):
        self.__dict__[name] = value + 1

或者:
def __setattr__(self, name, value):
        super().__setattr__(name, value+1)

3. 当访问一个属性时, 会先进入__getattribute__()中, 若属性不存在, 再进入__getattr__()中

4. 对于super类, 其本身拥有的属性有:
>>> dir(super)
['__class__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__get__', '__getattribute__', '__gt__', '__hash__', '__init__', '__le__', '__lt__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__self__', '__self_class__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__thisclass__']

所以当重写__getattr__()时, 如果返回super().__getattr__(name)则会报错

5. 在重写魔法方法时, 如果使用super().__setattr__(name, value)来定义属性则不会进入__setattr__()中

6. 附一个 045动动手第2题:
class  Counter:
    def  __init__(self):
        super().__setattr__('count', 0)
        
    def  __setattr__(self, name, value):
        if  name not in self.__dict__:
            super().__setattr__('count', self.count + 1)
        super().__setattr__(name, value)

    def  __delattr__(self, name):
        super().__setattr__('count', self.count - 1)
        super().__delattr__(name)

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-24 18:39

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表