构造函数中,成员变量一定要通过初始化列表来初始化的情况

1、类成员为const类型

2、类成员为引用类型

复制代码
#include <iostream>
using namespace std;

class A
{
public:
    A(int &v) : i(v), p(v), j(v) {}
    void print_val() { cout << "hello:" << i << "  " << j << endl; }
private:
    const int i;//类成员为const类型
    int p;
    int &j;//类成员为引用类型
};

int main(int argc, char **argv)
{
    int pp = 45;
    A b(pp);
    b.print_val();
}
复制代码

运行结果:

究其因

const对象或引用只能初始化但是不能赋值。构造函数的函数体内只能赋值而不是初始化,因此初始化const对象或引用的唯一机会是构造函数函数体之前的初始化列表中。

从无到有叫初始化,初始化(调用拷贝构造函数)创建了新对象;赋值(调用赋值操作符)没有创建新对象,而是对已有的对象赋值

3、类成员为没有默认构造函数的类类型

复制代码
 1 #include <iostream>
 2 using namespace std;
 3 
 4 class Base
 5 {
 6 public:
 7     Base(int a) : val(a) {}
 8 private:
 9     int val;
10 };
11 
12 class A
13 {
14 public:
15     A(int v) : p(v), b(v) {}
16     void print_val() { cout << "hello:" << p << endl; }
17 private:
18     int p;
19     Base b;//类成员为没有默认构造函数的类
20 };
21 
22 int main(int argc, char **argv)
23 {
24     int pp = 45;
25     A b(pp);
26     b.print_val();
27 }
复制代码

运行结果:

原因同样是创建对象时,要初始类成员的每一个成员

4、如果类存在继承关系,派生类必须在其初始化列表中调用基类的构造函数

复制代码
 1 #include <iostream>
 2 using namespace std;
 3 
 4 class Base
 5 {
 6 public:
 7     Base(int a) : val(a) {}
 8 private:
 9     int val;
10 };
11 
12 class A : public Base
13 {
14 public:
15     A(int v) : p(v), Base(v) {}//类A继承自类Base,需在其初始化列表中调用Base的构造函数
16     void print_val() { cout << "hello:" << p << endl; }
17 private:
18     int p;
19 };
20 
21 int main(int argc, char **argv)
22 {
23     int pp = 45;
24     A b(pp);
25     b.print_val();
26 }
复制代码

 运行结果:

以上。

それでも私の大好きな人
 
原文地址:https://www.cnblogs.com/yangchang1117/p/8950140.html