Cpp 对象模型探索 / 成员初始化列表
生活随笔
收集整理的這篇文章主要介紹了
Cpp 对象模型探索 / 成员初始化列表
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
目錄
一、何時必須使用?
二、優勢
三、細節探究
一、何時必須使用?
二、優勢
#include <iostream>class X {X(int value = 0) :m_i(value){printf("this = %p", this);std::cout << "X(int)構造函數被調用" << std::endl;}X(const X &tmpv){printf("this = %p", this);std::cout << "X 拷貝構造函數被調用" << std::endl;}X& operator=(const X &tmp){printf("this = %p", this);std::cout << "X 賦值運算符被調用" << std::endl;return *this;}~X(){printf("this = %p", this);std::cout << "X 析構函數被調用" << std::endl;}public:int m_i; };class A { public:X xobj; A(){ xobj = 1000; } };int main() {A aobj;return 0; }結果
this = 00CFFA60X(int)構造函數被調用 this = 00CFF89CX(int)構造函數被調用 this = 00CFFA60X 賦值運算符被調用 this = 00CFF89CX 析構函數被調用 this = 00CFFA60X 析構函數被調用從編譯器角度分析上述結果的原由,如下:
?
class A { public:X xobj; A()// 從編譯器角度分析,在初始化列表中,執行了如下代碼。// X xobj; 此處僅僅是執行了申請 sizeof(X) 大小的內存塊。// xobj.X::X(); 在上述內存塊中執行構造函數。{ // 從編譯器角度分析,此處的代碼如下:// X xtmp; 此處僅僅是執行了申請 sizeof(X) 大小的內存塊。// xtmp.X::X(); 在上述內存塊中執行構造函數。// xobj.operator=(xtmp); 此處執行賦值構造函數。xobj = 1000; } };若將代碼 xobj = 1000; 移入構造函數初始化列表中,則結果如下:
this = 00AFF82CX(int)構造函數被調用 this = 00AFF82CX 析構函數被調用省略了創建臨時變量和賦值的操作,即:在成員初始化列表中初始化變量,優勢是提高程序運行效率。?
三、細節探究
栗子:
#include <iostream> class A { public:A():k_(100),i_(k_){std::cout << "i_ = " << i_ << std::endl;std::cout << "k_ = " << k_ << std::endl;} private:int i_;int k_; };int main() {A aobj;return 0; }結果
i_ = -858993460 k_ = 100?由此可知,上述的結論是正確的。
?
(SAW:Game Over!)
總結
以上是生活随笔為你收集整理的Cpp 对象模型探索 / 成员初始化列表的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C/Cpp / 构造函数种类
- 下一篇: 数据结构与算法 / 二叉搜索树(Bina