1. 构造函数的初始化表(只针对构造函数)
1.1 语法形式
1.2 代码示例
#include <iostream>
using namespace std;
class Student {
public:
Student(const string& name, int age):m_name(name), m_age(age){}
void who(void){
cout << m_name << "," << m_age << endl;
}
private:
string m_name;
int m_age;
};
int main(void){
Student s("xuehui", 1);
s.who();
return 0;
}
$ ./a.out
xuehui,1
2. 需要显示初始化列表的场景
2.1 代码示例 1
- 定义成员子对象时, 如果用无参方式,但子对象对应类中没有无参构造函数。或者用有参方式定义。就必须要通过初始化列表显示指明其初始化方式。
#include <iostream>
using namespace std;
class A {
public:
A(int data) {
cout << "A(int)" << endl;
m_data = data;
}
int m_data;
};
class B{
public:
B(void):m_a(1){
cout << "B(void)" << endl;
}
A m_a;
};
int main(void){
B b;
cout << b.m_a.m_data << endl;
return 0;
}
$ ./a.out
A(int)
B(void)
1
2.2 代码示例 2
- const 和 引用 在语法上有要求:定义同时初始化
#include <iostream>
using namespace std;
int a = 100;
class A {
public:
A(void):m_a(90),m_b(a){}
const int m_a;
int& m_b;
};
int main(void){
A x;
cout << x.m_a << ' ' << x.m_b << endl;
return 0;
}
$ ./a.out
90 100
3. 初始化顺序
- 上图中类的private部分,m_len 是先于 m_str 声明的 ,所以先定义初始化的是m_len 。
- 所以先会用到初始化表中的m_len(m_str.length()) ,而此时m_str还是一个未定义初始化的值。m_str.length() 返回的结果也是未定义的。所以这是一个BUG.
- 改成下面的样子就ok了
Message(const string& str):m_str(str), m_len(str.length()) {}