问题描述
下面的两个类定义有什么区别
class my_dict1(dict):
def __init__(self,data):
self = data.copy()
self.N = sum(self.values)
上面的代码生成AttributeError: 'dict' object has no attribute 'N'
,而下面的代码编译
class my_dict2(dict):
def __init__(self,data):
for k,v in data.items():
self[k] = v
self.N = sum(self.values)
例如,
d = {'a': 3,'b': 5}
a = my_dict1(d) # results in attribute error
b = my_dict2(d) # works fine
解决方法
通过将self
本身分配给您将self
分配给与您最初处理的实例完全不同的实例,从而使其不再是“自我”。此实例将是更广泛的类型dict
(因为data
是dict
),而不是更窄的类型my_dict1
。您需要在第一个示例中进行self["N"]
才能正确解释它,但请注意,即使这样,也是如此:
abc = mydict_1({})
abc
仍将不具有键“ N”,因为__init__
中的一个完全不同的实例被赋予了键“ N”的值。这表明您没有合理的情况要将自己self
分配给其他对象。
关于my_dict2
,如果您想使用特定的dict
作为域的表示,则首选组合而不是继承。这意味着将data
作为实例字段。请参阅相关的C#问题Why not inherit from List?,核心答案仍然相同。这取决于您是否要扩展dict
机制,而不是基于它来建立业务对象。