class A
{
public:
A(){};
const int num;
CString& s;
}
A::A()
{
cout<<A con<<endl;
}
void main()
{
A a;
}
这是不过的,因为const成员变量需要在构造函数调用进入函数体之前就要被初始化,所以
C++有一种语法叫做 成员初始化列表。
构造函数改为
A::A():num(5):s(myString)
{
cout<<A con<<endl;
}
这样const int num被初始化为5,s被初始化为myString。
只有构造函数有这个语法,并且const和引用必须这样初始化。
下面这种情况是一个类的成员变量是一个类对象。
#include "stdafx.h"
class ClassA
{
public:
ClassA(int a)
{
m_a=a;
printf("ClassA con");
}
int m_a;
};
class ClassB
{
public:
ClassB();
ClassA a;
};
ClassB::ClassB():a(2)
{
printf("ClassB con");
}
int _tmain(int argc, _TCHAR* argv[])
{
ClassB* b=new ClassB;
return 0;
}
因为ClassA已经提供了一个有参数的构造函数,编译器不再提供默认的无参构造函数。所以ClassB如果不初始化a对象的话,是编译不过去的
所以在ClassB的构造函数初始化了a对象。