一个类的成员变量如果是另一个类的对象,就被称之为"成员对象"。包含成员对象的类叫封闭类(enclosed class)。
一个类 | 成员变量 |
---|---|
封闭类 | 成员对象 |
汽车 | 轮胎 |
为了使封闭类对象生成并初始化的时候让编译器知道成员对象时用哪个构造函数初始化的,可以通过在定义封闭类的构造函数时,添加初始化列表的方式解决。
构造函数中添加初始化列表写法
类名::构造函数名(参数表):成员变量1(参数表), 成员变量2(参数表),...
{
...
}
#include <iostream>
using namespace std;
class CTyre // 轮胎类
{
private:
int radius; // 半径
int width; // 宽度
public:
CTyre(int r, int w):radius(r), width(w) { }
};
class CEngine // 引擎类
{
};
class CCar
{
private:
int price; // 价格
CTyre tyre;
CEngine engine;
public:
CCar(int p, int tr, int tw);
};
CCar::CCar(int p, int tr, int tw):price(p), tyre(tr, tw)
{
};
int main()
{
CCar car(20000, 17, 225);
return 0;
}
生成封闭类对象的语句一定要让编译器能够弄明白其成员对象时如何初始化的,否则就会编译错误。
封闭类对象生成时,先执行所有成员对象的构造函数,然后才执行封闭类自己的构造函数
封闭类对象消亡时,先执行封闭类的析构函数,然后再执行成员对象的析构函数
思考题:为什么封闭类对象消亡时,要先执行封闭类的析构函数,然后才执行成员对象的析构函数?
对象A包含对象B,A持有B的引用,必须先解决引用的问题,不然B析构了会用无效引用。
封闭类的复制构造函数
封闭类的对象,如果是用默认复制构造函数初始化的,那么它包含的成员对象也会用复制构造函数初始化。
const成员和引用成员
类还可以有常量型成员变量和引用型成员变量。这两种类型的成员变量必须在构造函数的初始化列表中进行初始化。
#include <iostream>
using namespace std;
int f;
class CDemo
{
private:
const int num;
int & ref;
int value;
public:
CDemo(int n):num(n), ref(f), value(4)
{
}
};
int main()
{
cout << sizeof(CDemo) << endl;
return 0;
}