5
In [5]: class a(object):
   ...:     def __init__(self):
   ...:         print "In class a"
   ...:         self.a = 1
   ...:         
In [6]: class b(object):
   ...:     def __init__(self):
   ...:         print "In class b"
   ...:         self.b = 2
   ...:         
   ...:         

In [7]: class c(b, a):
   ...:     pass
   ...: 
In [8]: c.mro()
Out[8]: 
[<class '__main__.c'>,
 <class '__main__.b'>,
 <class '__main__.a'>,
 <type 'object'>]

In [9]: obj = c()
In class b

In [10]: obj.__dict__
Out[10]: {'b': 2}

class的默认__init__方法cobj创建时调用,它在内部调用__init__唯一的 class b

根据我的理解,如果我从 2 个类继承,我的派生类对象应该具有两个类的变量(除非它们是这些类的私有变量)。

我的问题:我期望我的派生对象包含来自两个类的变量是错误的吗?如果是这样,为什么?不应该也调用__init__class吗?a在像 C++ 这样的语言中会发生什么?

4

1 回答 1

8

在 python 中,默认情况下不调用来自上层的初始化方法。为此,您必须使用super显式调用它们,如下所示:

class a(object):
    def __init__(self):
        super(a, self).__init__()
        print "In class a"
        self.a = 1

class b(object):
    def __init__(self):
        super(b, self).__init__()
        print "In class b"
        self.b = 2

class c(b, a):
    pass

obj = c()

示例输出。

A
类 B 类

编辑:关于为什么会这样,我想说这是基于Python 之禅的设计决策:

显式优于隐式。

于 2012-02-13T07:21:14.693 回答