这里到底发生了什么的时候,cderived实例化:
记忆cderived留出(足够两个基类和派生部分)。
适当的派生类的构造函数调用
基对象首先构建了使用适当的基类构造函数
初始化列表初始化变量
构造函数的函数体执行
将控制返回给调用者
唯一真正的区别这种情况和非之间的继承是在派生类的构造函数可以做任何实质性的,被称为第一基构造函数。基构造函数设置对象的基类部分,控制返回到派生类的构造函数,并允许派生类的构造函数来完成它的工作。
初始化基类成员
我们的一个派生类目前的缺点写是没有办法来初始化m_nvalue当我们创建一个派生类对象。如果我们想设置m_dvalue(从对象派生的药水)和m_nvalue(从对象的基类部分)我们创建派生类对象时?
新的程序员经常试图解决这一问题如下:
1
2
3
4
5
6
7
8
9
10
11
|
class
Derived:
public
Base
{
public
:
double
m_dValue;
Derived(
double
dValue=0.0,
int
nValue=0)
// does not work
: m_dValue(dValue), m_nValue(nValue)
{
}
};
|
这是一个很好的尝试,并且几乎是正确的想法。我们一定要添加另一个参数我们的构造函数,否则C++将没有办法知道什么需要的值初始化m_nvalue来。
然而,C++类继承的成员变量的初始化可以在构造函数的初始化列表。换句话说,一个变量的值只能被设置在一个构造函数属于同一类的变量初始化列表。
为什么C++这样做吗?答案与const引用变量。考虑会发生什么,如果m_nvalue是const。因为const变量必须在创建时的值初始化,基类的构造函数必须设置它的值时,创建变量。然而,当基类构造函数完成的派生类构造函数初始化列表,然后执行。每个派生类将有机会初始化这个变量,它的值可能会改变!通过限制变量的初始化类的构造函数的变量属于,C++确保所有变量被初始化一次。
最终的结果是,上面的例子不工作,因为m_nvalue是继承的基础,只有非继承的变量可以在初始化列表的更改。
然而,遗传变量还可以更改其值在构造函数函数体中的赋值。因此,新的程序员也经常尝试: