具体来说,派生类构造函数必须使用基类构造函数。
创建派生类对象时,程序首先创建基类对象。C++使用初始化列表完成这项工作。
RatedPlayer::RatedPlayer(int r, const string &fn):TableTennisPlayer(fn)
{
rating = r;
}
1
2
3
4
其中TableTennisPlayer(fn)是成员初始化列表,它是可执行代码。调用TableTennisPlayer构造函数。
如果不使用初始化列表,则调用基类默认构造函数。
同样,可以对派生类成员使用成员初始化列表语法:
RatedPlayer::RatedPlayer(int r, const string &fn):TableTennisPlayer(fn),rating(r)
{
}
1
2
3
4
有关派生类构造函数的要点:
1创建基类对象。
2派生类构造函数应通过成员初始化列表将基类信息传递给基类构造函数。
3派生类构造函数应初始化派生类新增的数据成员。
Effective C++中写到“Make sure that objects are initialized before they’re used.”,即“确定对象被使用前已先被初始化”。
下面不讨论继承,只讨论赋值和初始化!有代码如下
ABEntry::ABEntry(const std::string & name)
{
theName = name;
}
1
2
3
4
C++规定,对象的成员变量的初始化动作发生在进入构造函数本体之前。
因此,上诉代码中theName不是初始化而是赋值。即,首先调用了这个类的默认构造函数,然后将theName赋值为name,即在调用拷贝构造函数。
将上诉代码改为:
ABEntry::ABEntry(const std::string & name): theName(name)