下面两个类定义有什么区别,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 errorb = my_dict2(d) # works fine
1 回答
![?](http://img1.sycdn.imooc.com/5458620000018a2602200220-100-100.jpg)
慕无忌1623718
TA贡献1744条经验 获得超4个赞
通过将self
自身分配给任何东西,您可以将其分配self
给与最初处理的完全不同的实例,使其不再是“自我”。该实例将属于更广泛的类型dict
(因为data
是 a dict
),而不是更窄的类型my_dict1
。您需要self["N"]
在第一个示例中执行此操作才能正确解释它,但请注意,即使这样,也可以如下所示:
abc = mydict_1({})
abc
仍然没有键“N”,因为完全不同的实例被__init__
赋予了键“N”的值。这向您表明,不存在将self
其自身分配给其他事物的合理场景。
关于my_dict2
,如果您想使用特定的内容dict
作为您的域的表示,则更喜欢组合而不是继承。这意味着有data
一个实例字段。
添加回答
举报
0/150
提交
取消