|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
问题:麻烦大神给一些解题思路,并在答案写一写注释!
题目:修改上边【测试题】第4题,使之可以正常运行:编写一个Counter类,用于实时检测对象有多少个属性。
程序实现如下:
>>> c = Counter()
>>> c.x = 1
>>> c.counter
1
>>> c.y = 1
>>> c.z = 1
>>> c.counter
3
>>> del c.x
>>> c.counter
2
第4题例子:
class Counter:
def __init__(self):
self.counter = 0 # 这里会触发 __setattr__ 调用
def __setattr__(self, name, value):
self.counter += 1
“””既然需要 __setattr__ 调用后才能真正设置 self.counter 的值,所以这时候 self.counter 还没有定义,所以没法 += 1,错误的根源。”””
super().__setattr__(name, value)
def __delattr__(self, name):
self.counter -= 1
super().__delattr__(name)
答案:
class Counter:
def __init__(self):
super().__setattr__('counter', 0) #setattr 函数对应函数 getatt(),用于设置属性值,该属性必须存在。
def __setattr__(self, name, value):
super().__setattr__('counter', self.counter + 1)
super().__setattr__(name, value)
def __delattr__(self, name):
super().__setattr__('counter', self.counter - 1)
super().__delattr__(name)
hi 我的理解如下
class Counter: #魔法方法__setattr___用于设置属性值,该属性必须要存在,否则报错
def __init__(self):
super().__setattr__('counter', 0) #实例化对象初始化时,生成属性counter并赋值为0 例如:c = Counter() , c.counter=0
def __setattr__(self, name, value):
super().__setattr__('counter', self.counter + 1) #实例化对象设定新属性时,counter属性自动+1 例如:c.x=1, c.counter += 1
super().__setattr__(name, value)
def __delattr__(self, name):
super().__setattr__('counter', self.counter - 1) #实例化对象删除属性时,counter属性自动-1 例如: del c.x, c.counter -= 1
super().__delattr__(name)
|
|