文章标题
2016-08-17 15:20
183 查看
类成员为引用类型
类成员为const类型
原因:
const对象或引用只能初始化但是不能赋值。构造函数的函数体内只能做赋值而不是初始化,因此初始化const对象或引用的唯一机会是构造函数函数体之前的初始化列表中。
从无到有叫初始化,初始化(调用构造函数)创建了新对象;赋值(调用赋值操作符)没有创建新对象,而是对已有的对象赋值。
类成员为 没有默认构造函数的类 类型
原因同样是创建对象时,要初始类成员的每一个成员
初始化列表不调用默认的构造函数。
4. 如果类存在继承关系,派生类必须在其初始化列表中调用基类的构造函数
类成员为const类型
#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; int p; int &j; }; int main(int argc ,char **argv) { int pp = 45; A b(pp); b.print_val(); }
原因:
const对象或引用只能初始化但是不能赋值。构造函数的函数体内只能做赋值而不是初始化,因此初始化const对象或引用的唯一机会是构造函数函数体之前的初始化列表中。
从无到有叫初始化,初始化(调用构造函数)创建了新对象;赋值(调用赋值操作符)没有创建新对象,而是对已有的对象赋值。
类成员为 没有默认构造函数的类 类型
struct Test1 { Test1(int a):i(a){} int i ; }; struct Test2 { Test1 test1 ; Test2(Test1 &t1) { test1 = t1 ; } }; int main() { Test1 t1 ; Test2 t2(t1) ; }
以上代码无法通过编译,因为Test2类中Test1 test1;需要调用默认的构造函数,但是Test1类没有无参的构造函数,但是由于Test1没有默认的构造函数,故而编译错误。正确的代码如下,使用初始化列表代替赋值操作。
原因同样是创建对象时,要初始类成员的每一个成员
初始化列表不调用默认的构造函数。
4. 如果类存在继承关系,派生类必须在其初始化列表中调用基类的构造函数