45讲课后习题4题疑问
本帖最后由 风风魔王 于 2020-10-9 19:04 编辑class Counter:
def __init__(self):
self.counter = 0
def __setattr__(self, name, value):
self.counter += 1
super().__setattr__(name, value)
def __delattr__(self, name):
self.counter -= 1
super().__delattr__(name)为什么颠倒self.counter += 1,super().__setattr__(name, value)这两句话
super().__setattr__(name, value)
self.counter += 1运行代码是,为什么这样什么结果也没有呢?
a = Counter()
a.x = 1
a.y = 2
print(a.counter)
不管哪种情况都会进入无限递归,不清楚你是怎么操作的。
流程(代码行)
03->05,错误(甲鱼的题讲解里面有说)
第二种
class Counter:
def __init__(self):
super().__setattr__('counter', 0)
def __setattr__(self, name, value):
super().__setattr__(name, value)
self.counter += 1
def __delattr__(self, name):
self.counter -= 1
super().__delattr__(name)
06-04-06-04(无限递归) 本帖最后由 风风魔王 于 2020-10-10 10:04 编辑
抉择啊 发表于 2020-10-9 19:35
不管哪种情况都会进入无限递归,不清楚你是怎么操作的。
流程(代码行)
03->05,错误(甲鱼的题讲解里面 ...
好的谢谢您,还有个疑问就是明明无限递归了,但是程序却不会像之前那样报递归深度最大的错,这是为什么呢? 风风魔王 发表于 2020-10-10 09:45
好的谢谢您,还有个疑问就是明明无限递归了,但是程序却不会像之前那样报递归深度最大的错,这是为什么 ...
我这边会报哦,你可以哪里打错了。
页:
[1]