zhangfeiwen 发表于 2020-9-23 18:06:12

45最后一题

编写一个 Counter 类,用于实时检测对象有多少个属性
这是小甲鱼答案
class Counter(object):
    k = []
    def __init__(self):
      self.counter = 0
    def __setattr__(self,name,value):
      if name != 'counter':
            if name not in self.k:
                self.counter += 1
                print(f"set:{self.counter}")#这个f很有用!!!
                self.k.append(name)
      super().__setattr__(name,value)
    def __delattr__(self,name):
      if name in self.k:
            self.counter -= 1
            print(f"del:{self.counter}")
            self.k.remove(name)
      super().__delattr__(name)

这是我的
class Co:
    def __init__(self):
      self.counter = 0
    def __setattr__(self,name,value):
       # if name != 'counter':这句没有会报错
      self.counter += 1
      super().__setattr__(name,value)
    def __delattr__(self,name):
      self.counter -= 1
      super().__delattr__(name)
如果我不用if的话 会报错
AttributeError: 'Co' object has no attribute 'counter'
为什么会用了if 就可以,没用就报错??

lhgzbxhz 发表于 2020-9-23 18:56:46

因为在__init__()函数中执行self.counter = 0时,会自动调用__setattr__()方法,执行self.counter += 1
而此时self.counter = 0还没有执行完毕,Python发现self没有counter这个属性,因此报错

zhangfeiwen 发表于 2020-9-23 19:24:01

lhgzbxhz 发表于 2020-9-23 18:56
因为在__init__()函数中执行self.counter = 0时,会自动调用__setattr__()方法,执行self.counter += 1
而 ...

可我用if就可以。

lhgzbxhz 发表于 2020-9-25 19:43:51

zhangfeiwen 发表于 2020-9-23 19:24
可我用if就可以。

用if时,当__init__()中调用__setattr()__时,if判断发现name == "counter",于是不执行self.counter += 1这行代码,因此不会出错

zhangfeiwen 发表于 2020-9-28 19:33:00

lhgzbxhz 发表于 2020-9-25 19:43
用if时,当__init__()中调用__setattr()__时,if判断发现name == "counter",于是不执行self.counter +=...

if判断name == "counter"后不还是会执行self.counter += 1吗 难道是判断的时候 init就给counter赋了值?

lhgzbxhz 发表于 2020-9-29 18:59:51

zhangfeiwen 发表于 2020-9-28 19:33
if判断name == "counter"后不还是会执行self.counter += 1吗 难道是判断的时候 init就给counter赋了值?

当name=="counter"时,if name!="counter"为假,所以就不会执行self.counter += 1

zhangfeiwen 发表于 2020-9-29 22:28:06

lhgzbxhz 发表于 2020-9-29 18:59
当name=="counter"时,if name!="counter"为假,所以就不会执行self.counter += 1

尴尬。。谢谢了
页: [1]
查看完整版本: 45最后一题