【发布时间】:2014-01-17 22:12:27
【问题描述】:
我想扩展“列表”类的功能并为事件添加自定义处理程序:“将新项目添加到列表”和“从列表中删除项目”。对于这个任务,我不想使用组合,最好是继承。
我尝试做什么:
class ExtendedList(list):
def append(self, obj):
super(ExtendedList, self).append(obj)
print('Added new item')
def extend(self, collection):
if (hasattr(collection, '__iter__') or hasattr(collection, '__getitem__')) and len(collection)>0:
for item in collection:
self.append(item)
def insert(self, index, obj):
super(ExtendedList, self).insert(index, obj)
print('Added new item')
def remove(self, value):
super(ExtendedList, self).remove(value)
print('Item removed')
但它不能正常工作。我无法捕获所有添加和删除事件。例如:
collection = ExtendedList()
collection.append('First item')
# Out: "Added new item\n"; collection now is: ['First item']
collection.extend(['Second item', 'Third item'])
# Out: "Added new item\nAdded new item\n"; collection now is: ['First item', 'Second item', 'Third item']
collection += ['Four item']
# Don't out anythink; collection now is: ['First item', 'Second item', 'Third item', 'Four item']
collection.remove('First item')
# Out: "Item removed\n"; collection now is: ['Second item', 'Third item', 'Four item']
del collection[0:2]
# Don't out anythink; collection now is: ['Four item']
collection *= 3
# Don't out anythink; collection now is: ['Four item', 'Four item', 'Four item']
根据我的情况扩展类“列表”的正确方法是什么?感谢您的帮助。
【问题讨论】:
-
在这里定义列表的子类不是一个好主意。相反,您应该更喜欢聚合而不是继承
-
每个都做不同的事情,所以使用更适合您想要完成的事情的那个?
-
您已经展示了会发生什么,但它有什么问题?你想发生什么?
-
您的问题是“对于这项任务,我不想使用组合,最好是继承。”为什么?一般来说,对于这样的任务来说,情况并非如此。如果你的任务有一些具体的东西使它成为现实,那么知道那个具体的东西可能意味着人们可以写出更好的答案。 (或者,如果你错了,人们可以解释为什么组合和授权对你的具体情况仍然有意义。)
-
@uzumaxy:如果您是从另一种语言开始使用 Python,尤其是 Java 或另一种执行 OO 旧 C++ 风格的语言,那么这是非常令人惊讶的事情之一。如果没有鸭子类型,继承是创建像另一种类型的实例一样的对象的唯一方法。使用鸭子打字,这只是一种方式,而且通常不是最好的方式。
标签: python list inheritance