huyanmin 发表于 2021-6-17 18:36:59

python 45课习题 小甲鱼源代码,有疑问,求详解

本帖最后由 huyanmin 于 2021-6-17 18:42 编辑

#编写一个 Counter 类,用于实时检测对象有多少个属性?
class Counter:
      k = []
      def __init__(self):
                self.counter = 0
               
               
      def __setattr__(self, name, value): #下面有演示,为什么设置一次属性,__setattr__()方法,执行了两次
                print('我是setattr')
                if name != 'counter':
                        if name not in self.k:
                              self.counter += 1
                              self.k.append(name)
                super().__setattr__(name, value)
               
      def __delattr__(self, name):
                self.counter -= 1
                self.k.remove(name)
                super().__delattr__(name)



'''
>>> c =Counter
>>> c=Counter()
我是setattr
>>> c.y=88#为什么设置一次属性,__setattr__()方法,执行了两次
我是setattr
我是setattr
'''

Twilight6 发表于 2021-6-17 18:52:36


你应该是 PyCharm 吧?

PyCharm 或者其他编译器的控制台,打印多次是正常现象,和这个帖子情况一样

[已解决] Pycharm中__getattr__与__getattribute__的问题
https://fishc.com.cn/thread-197656-1-1.html
(出处: 鱼C论坛)

直接在代码中编辑好一次性执行,就没事

huyanmin 发表于 2021-6-17 19:31:57

Twilight6 发表于 2021-6-17 18:52
你应该是 PyCharm 吧?

PyCharm 或者其他编译器的控制台,打印多次是正常现象,和这个帖子情况一样


老师好,我用的是idle,windows系统

Twilight6 发表于 2021-6-17 19:37:03

huyanmin 发表于 2021-6-17 19:31
老师好,我用的是idle,windows系统


怪我,是我没认真审题了

第一次执行是因为你的 c.y = 88 这个没问题

第二次执行是因为你 __setattr__ 魔法方法中的 self.counter += 1 对 self.counter += 1

相当于 self.counter = self.counter + 1 也对该类的实例属性进行了赋值,导致再次调用

huyanmin 发表于 2021-6-17 19:42:14

Twilight6 发表于 2021-6-17 19:37
怪我,是我没认真审题了

第一次执行是因为你的 c.y = 88 这个没问题


相当于 self.counter = self.counter + 1 也对该类的实例属性进行了赋值,导致再次调用,这样岂不是死循环了吗

huyanmin 发表于 2021-6-17 19:43:55

huyanmin 发表于 2021-6-17 19:42
相当于 self.counter = self.counter + 1 也对该类的实例属性进行了赋值,导致再次调用,这样岂不是死循 ...

抱歉,想错了,不会死循环

Twilight6 发表于 2021-6-17 19:44:04

huyanmin 发表于 2021-6-17 19:42
相当于 self.counter = self.counter + 1 也对该类的实例属性进行了赋值,导致再次调用,这样岂不是死循 ...



认真看看 if 的条件

huyanmin 发表于 2021-6-17 19:49:39

huyanmin 发表于 2021-6-17 19:43
抱歉,想错了,不会死循环

相当于 self.counter = self.counter + 1 也对该类的实例属性进行了赋值,导致再次调用,第二次递归调用__setattr__,不会在进入if语句了,所以不会死循环
页: [1]
查看完整版本: python 45课习题 小甲鱼源代码,有疑问,求详解