风风魔王 发表于 2020-10-9 18:39:18

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)







抉择啊 发表于 2020-10-9 19:35:44

不管哪种情况都会进入无限递归,不清楚你是怎么操作的。
流程(代码行)
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 09:45:54

本帖最后由 风风魔王 于 2020-10-10 10:04 编辑

抉择啊 发表于 2020-10-9 19:35
不管哪种情况都会进入无限递归,不清楚你是怎么操作的。
流程(代码行)
03->05,错误(甲鱼的题讲解里面 ...

好的谢谢您,还有个疑问就是明明无限递归了,但是程序却不会像之前那样报递归深度最大的错,这是为什么呢?

抉择啊 发表于 2020-10-10 19:28:58

风风魔王 发表于 2020-10-10 09:45
好的谢谢您,还有个疑问就是明明无限递归了,但是程序却不会像之前那样报递归深度最大的错,这是为什么 ...

我这边会报哦,你可以哪里打错了。
页: [1]
查看完整版本: 45讲课后习题4题疑问