redaiconglin 发表于 2022-4-3 16:55:55

关于047课定制序列动动手题目

class CountList(list):
    def __init__(self, *args):
       super().__init__(args)                  这个地方为什么需要采用继承父类的方法重写,这个地方如何我不采用继承父类的方法会造成什么问题。
      self.count = []
      for i in args:
            self.count.append(0)

    def __len__(self):
      return len(self.count)

    def __getitem__(self, key):
      self.count += 1
      return super().__getitem__(key)            这个地方返回如果不采用继承,直接return self.count可以吗。和采用继承有什么区别。

    def __setitem__(self, key, value):
      self.count += 1
      super().__setitem__(key, value)

    def __delitem__(self, key):
      del self.count
      super().__delitem__(key)

    def counter(self, key):
      return self.count

    def append(self, value):
      self.count.append(0)
      super().append(value)

    def pop(self, key=-1):
      del self.count
      return super().pop(key)

    def remove(self, value):
      key = super().index(value)
      del self.count
      super().remove(value)

    def insert(self, key, value):
      self.count.insert(key, 0)
      super().insert(key, value)
感谢老师能帮我解答。这些地方一直没有弄清楚。为什么要继承父类重写__init__方法。

    def clear(self):
      self.count.clear()
      super().clear()

    def reverse(self):
      self.count.reverse()
      super().reverse()

大马强 发表于 2022-4-3 17:25:39

这个可能你要去看下list的 __init__()里有啥
只能说它们实现的方法没有那么简单,你要不想要的话需要重写,但是你继承的话就剩下这些功夫

redaiconglin 发表于 2022-4-3 18:36:40

大马强 发表于 2022-4-3 17:25
这个可能你要去看下list的 __init__()里有啥
只能说它们实现的方法没有那么简单,你要不想要的话需要重写 ...

老师是这样理解的吗。就是说我在重写__init__这个魔法方法的时候只是建了一个外壳并不具备它真正所有的功能。必须要继承父类的这个魔法方法才能实现所有的功能。

大马强 发表于 2022-4-3 18:37:20

可以这么理解
页: [1]
查看完整版本: 关于047课定制序列动动手题目