关于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()
这个可能你要去看下list的 __init__()里有啥
只能说它们实现的方法没有那么简单,你要不想要的话需要重写,但是你继承的话就剩下这些功夫 大马强 发表于 2022-4-3 17:25
这个可能你要去看下list的 __init__()里有啥
只能说它们实现的方法没有那么简单,你要不想要的话需要重写 ...
老师是这样理解的吗。就是说我在重写__init__这个魔法方法的时候只是建了一个外壳并不具备它真正所有的功能。必须要继承父类的这个魔法方法才能实现所有的功能。 可以这么理解
页:
[1]