构造函数在构造函数的初始化列表中调用才有效果,在构造函数体中调用不起作用!
一、代码:
#include <iostream>
using namespace std;
class Member
{
public:
Member()
{
age = 0;
cout << "Default constructor of Member" << endl;
}
Member(int a) : age(a)
{
cout << "Constructor of Member" << endl;
}
void show_age()
{
cout << "age = " << age << endl;
}
private:
int age;
};
class Family
{
public:
Family()
{
Member(100);
cout << "Constructor of Family" << endl;
}
void show_member()
{
cout << "Age of member : ";
m1.show_age();
cout << endl;
}
private:
Member m1;
};
int main(int argc, char **argv)
{
Family f0;
f0.show_member();
return 0;
}
二、输出结果:
Default constructor of Member
Constructor of Member
Constructor of Family
Age of member : age = 0
三、分析:
输出结果的第一行:Member类的默认构造函数在Family类的构造函数的初始化列表(隐式存在)中被自动调用,此时age应该等于0;
输出结果的第二行:Member类的构造函数在Family类的构造函数体内被调用,此时age应该等于100;
但从输出结果的最后一行看,age = 0,说明只有在初始化列表中调用的默认构造函数起作用了,而构造函数体内调用的构造函数没有起作用,其原因是在构造函数体内调用构造函数,生成的是一个局部对象,在退出构造函数体后就失效了。也就是说,在C++中,不能在一个构造函数中调用另一个构造函数,而需要在构造函数的初始化列表中调用内嵌对象或基类的构造函数。
或者将Family类的构造函数改为:
Family() : m1(10)
{
Member(100);
cout << "Constructor of Family" << endl;
}
再看输出结果:
Constructor of Member
Constructor of Member
Constructor of Family
Age of member : age = 10
同样说明了以上分析的正确性。
四、启示:
在类的构造函数中调用其基类或者内嵌对象的构造函数时,一定要在构造函数的初始化列表中调用,而不要在构造函数体中调用,以确保基类或者内嵌对象的构造函数起作用。