例题来看:请问下面程序打印出的结果是什么? #include <iostream> #include <string> using namespace std; class base { private: int m_i; int m_j; public: base(int i):m_j(i),m_i(m_j); ),m_i(m_j){} int get_i() {return m_i;} int get_j() {return m_j;} }; int main(int argc…
构造函数初始化列表仅用于初始化成员的值,并不指定这些初始化执行的次序.成员被初始化的次序就是定义成员的次序.第一个被定义的成员先被初始化,依次类推.一般,初始化的顺序无关紧要,然而,如果一个成员是根据其他成员而初始化,则成员的初始化顺序是至关重要的. class x { int i;//声明顺序是先i,后j,故初始化列表中,会先初始化i,在初始化j int j; public: x(int tem): j(tem),i(j){} //看起来是先初始化j,然后初始化i,其实恰恰相反…
简略来说,编译器会对初始化列表按照成员变量的声明顺序重新一一排序,安插到构造函数中进行初始化操作,而且这些初始化操作在构造函数里面用户自己定义的任何代码之前. 下面是c++源码: class X { private: int i; int j; int k; int l; public: X() : j(), i(), l() { k = ; } }; int main() { X x; } 下面是main函数里面的汇编码: ; 13 : int main() { push ebp mov eb…
1,初始化列表是在 C++ 中才引入的: 2,以“类中是否可以定义 const 成员?”这个问题来引入初始化列表: 1,const 这个关键字可以定义真正意义上的常量,也可以在某些情况下定义只读变量: 3,小实验: 1,下面的类定义是否合法?如果合法,ci 的值是什么,存储在哪里? #include <stdio.h> class Test { private: const int ci; // const 作用于 C++ 中的成员变量后得到的是只读成员变量,只读成员变量是不可以出现在成员符号…