例题来看:请问下面程序打印出的结果是什么? #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,其实恰恰相反…
内存泄漏定义(memory leak):一个不再被程序使用的对象或变量还在内存中占有存储空间. 一次内存泄漏似乎不会有大的影响,但内存泄漏堆积后的后果就是内存溢出.内存溢出 out of memory :指程序申请内存时,没有足够的内存供申请者使用,或者说,给了你一块存储int类型数据的存储空间,但是你却存储long类型的数据,那么结果就是内存不够用,此时就会报错OOM,即所谓的内存溢出.二者的关系: 内存泄漏的堆积最终会导致内存溢出 内存溢出就是你要的内存空间超过了系统实际分配给你的空间,此时…
如果一个类是这样定义的: Class A { public: A(int pram1, int pram2, int pram3); privite: int a; int &b; const int c; } 假如在构造函数中对三个私有变量进行赋值则通常会这样写: A::A(int pram1, int pram2, int pram3) { a=pram1; b=pram2; c=pram3; } 但是,这样是编译不过的.因为常量和引用初始化必须赋值.所以上面的构造函数的写法只是简单的赋值,…