(1)一个基类的全部数据成员均被派生类继承。创建一个派生类对象时。系统在为派生类对象分配单元时一定要为其基类数据成员分配子空间。
(2)一个派生类对象在创建时不仅要调用派生类构造函数。并且要调用基类构造函数。
派生类中的数据成员在派生类中构造。
基类中的数据成员在基类中构造。
原因:
A.构造函数不继承。
B.派生类的构造函数必须通过调用基类的构造函数完毕基类数据成员的初始化。
C.若派生类中含有子对象。必须调用子对象的构造函数。
2.派生类的构造函数
派生类名(总參数表):基类构造函数(參数名),子对象名(參数表) {派生类数据成员的初始化}
注:总參数表由基类、子对象、派生类三部分的參数构成。基类參数表为基类数据成员。
3.样例
example 1:
class A
{
public:
A() {cout<<"A consturct."<<endl;}
};
class B:public A
{
public:
B():A() {cout<<"B construct."<<endl;}
};
int main()
{
B b;
}
程序输出:A construct.
B construct.
说明:派生类构造函数的调用顺序:先调用基类构造函数-->调用子对象的构造函数-->派生类的构造函数。
注意:假设是多继承(class C:public A,public B)。这样的情况调用构造函数的顺序是依照继承列表的先后来调用,与C的构造函数中參数列表排列顺序无关。
example 2:
#include <iostream.h>
class A
{
public:
A() {"cout<<"A construct1."<<endl;}
A(int i)
{
x1 = i;
cout<<"A construct2."<<endl;
}
private:
int x1;
};
class B:public A
{
public:
B() {cout<<"B construct1."<<endl;}
B(int i):A(i+10)
{
x2 = i;
cout<<"B construt2."<<endl;
}
void displayb() {cout<<"x2 = "<<x2<<endl;}
private:
int x2;
};
int main()
{
B b(2);
b.displayb();
}
程序输出:
A construct2.
B construct2.
x2 = 2
注:派生类对象构造函数在调用之前必须先调用基类构造,派生类构造函数中要表示对基类构造的调用,若是单一继承,派生类构造函数中能够省去基类构造,可是默认会调用无參构造(建议不要省去)。
上述程序稍作改动:
将类B中的displayb改动为
void displayb()
{
displaya();
cout<<"x2 = "<<x2<<endl;
}
程序输出变为:
A construct2.
B construct2.
x1 = 12
x2 = 2
假设将main函数改动为:
int main()
{
B b(2);
b.displaya();
b.displayb();
}
程序输出变为:
A construct2.
B construct2.
x1 = 12
x2 = 2