◆由于构造函数不能被继承,因此,派生类的构造函数中除了对派生类中数据成员进行初始化外,还必须通过调用直接基类的构造函数来对基类中数据成员初 始化,一般地将,对派生类中数据成员初始化放在该派生类构造函数的函数体内,而调用基类构造函数的基类中数据成员初始化放在该构造函数的成员初始化表中。 派生类构造函数的格式如下表示:
<派生类构造函数名>(<参数表>) : <成员初始化表>
{
<派生类构造函数的函数体>
}
其中,<派生类构造函数名>同该派生类的类名。<成员初始化表>中包含如下的初始化项:
①基类的构造函数,用来给基类中数据成员初始化;
②子对象的类的构造函数,用来给派生类中子对象的数据成员初始化;
③派生类中常成员的初始化。
<派生类构造函数的函数体>用来给派生类中的数据成员初始化。
派生类构造函数的调用顺序如下:
①基类构造函数;
②子对象的构造函数;
③成员初始化表中其他初始化项;
④派生类构造函数的函数体。
在基类中有默认构造函数时,派生类的构造函数中可隐含调用基类中的默认构造函数。
派生类中析构函数
由于析构函数也不能继承,因此派生类的析构函数中将调用直接基类的析构函数。执行派生类析构函数的顺序正好与指向派生类的构造函数的顺序相反。先调用派生类的析构函数,再调用子对象类的析构函数,最后调用直接基类的析构函数。
例如:分析下列程序的输出结果,掌握派生类构造函数的定义格式和执行顺序,以及派生类析构函数的调用方法。
1
#include<iostream>
2 using namespace std;
3 class A
4 {
5 public:
6 A()
7 {
8 a=0;
9 cout<<"Default constructor called. A\n";
10 }
11 A(int i)
12 {
13 a=i;
14 cout<<"Constructor called. A\n";
15 }
16 ~A()
17 {
18 cout<<"Destructor called. A\n";
19 }
20 void Print()
21 {
22 cout<<a<<",";
23 }
24 int Geta()
25 {
26 return a;
27 }
28
2 using namespace std;
3 class A
4 {
5 public:
6 A()
7 {
8 a=0;
9 cout<<"Default constructor called. A\n";
10 }
11 A(int i)
12 {
13 a=i;
14 cout<<"Constructor called. A\n";
15 }
16 ~A()
17 {
18 cout<<"Destructor called. A\n";
19 }
20 void Print()
21 {
22 cout<<a<<",";
23 }
24 int Geta()
25 {
26 return a;
27 }
28