将字典分配给类对象

问题描述

下面的两个类定义有什么区别

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(因为datadict),而不是更窄的类型my_dict1。您需要在第一个示例中进行self["N"]才能正确解释它,但请注意,即使这样,也是如此:

abc = mydict_1({})

abc仍将不具有键“ N”,因为__init__中的一个完全不同的实例被赋予了键“ N”的值。这表明您没有合理的情况要将自己self分配给其他对象。

关于my_dict2,如果您想使用特定的dict作为域的表示,则首选组合而不是继承。这意味着将data作为实例字段。请参阅相关的C#问题Why not inherit from List?,核心答案仍然相同。这取决于您是否要扩展dict机制,而不是基于它来建立业务对象。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...