首页 > 代码库 > C++语言笔记系列之十三——派生类构造函数的调用
C++语言笔记系列之十三——派生类构造函数的调用
1.派生类构造函数的调用
(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
(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
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。