有这样一种情形 :一个类B中 有另一个类A的对象,A中没有无参构造,不能直接定义A的对象,需要某种机制对A的对象进行初始化。
这种机制就是对象初始化列表——用来对对象进行初始化
形式——构造函数后面:要初始化的对象
特性:
1、对象初始化列表比当前对象的构造函数先执行
2、对象在对象初始化列表中的顺序和构造顺序无关,和在类中的声明顺序有关
3、const常量也要放到对象初始化列表中进行初始化
4、析构函数的调用顺序和构造函数的调用顺序相反
eg:
class A
{
public:
A(int a)
{
a1 = a;
}
A(int a, int b)
{
a1 = a;
a2 = b;
printf ("A的构造函数被调用-------: a1 = %d, a2 = %d\n", a1, a2);
}
void show()
{
printf("a1 = %d, a2 = %d\n", a1, a2);
}
~A()
{
printf("A的析构函数被调用 a1 = %d, a2 = %d\n", a1, a2);
}
private:
int a1;
int a2;
};
class B
{
public:
B():obj1(1,2), obj2(3,4), c1(20), b1(12)/*先是obj1调用A的构造函数,再是obj2调用A的构造函数,最后是b调用B的构造函数*/
{
printf("B的构造函数被调用-----b = %d\n", b1);
}
~B()
{
printf("B的析构函数被调用-----b = %d\n", b1);
}
private:
int b1;
A obj1;//类中的声明顺序,决定了初始化列表中的调用构造的顺序
A obj2;
const int c1;
};
int main()
{
B b;
return 0;
}
运行结果分析:
(obj1)A的构造函数被调用-------: a1 = 1, a2 = 2
(obj2)A的构造函数被调用-------: a1 = 3, a2 = 4
(b)B的析构函数被调用-----b = 12
(b)B的析构函数被调用-----b = 12
(obj2)A的析构函数被调用 a1 = 3, a2 = 4
(obj1)A的析构函数被调用 a1 = 1, a2 = 2
需要使用初始化列表的情形和原因,下面是一条博客链接点击打开链接,里面有详细介绍,这里就不再赘述
http://blog.youkuaiyun.com/sinat_20265495/article/details/53670644