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 }
运行结果:
以上。
それでも私の大好きな人
并发编程系列【线程池七大核心参数】
C信号处理的基础
设计模式之Command
Ext文件系统
内存管理
设计模式之Decorator Pattern
设计模式之singleton
Quicklz压缩算法
设计模式之Factory