C++ 中的this指針詳解及實例
C++ this 指針詳解
學(xué)習(xí) C++ 的指針既簡單又有趣。通過指針,可以簡化一些 C++ 編程任務(wù)的執(zhí)行,還有一些任務(wù),如動態(tài)內(nèi)存分配,沒有指針是無法執(zhí)行的。所以,想要成為一名優(yōu)秀的 C++ 程序員,學(xué)習(xí)指針是很有必要的。
正如您所知道的,每一個變量都有一個內(nèi)存位置,每一個內(nèi)存位置都定義了可使用連字號(&)運算符訪問的地址,它表示了在內(nèi)存中的一個地址。
this指針是類的一個自動生成、自動隱蔽的私有成員,它存在于類的非靜態(tài)成員中,指向被調(diào)用函數(shù)所在的對象。
全局僅有一個this指針,當(dāng)一個對象被創(chuàng)建時,this指針就存放指向?qū)ο髷?shù)據(jù)的首地址。
class Ctest { public: void Funtest(int iValue) { _iValue = iValue; } void Print() { cout << _iValue << endl; } private: int _iValue;//調(diào)用私有變量只能用公有成員接收,成員變量在類中具有全局作用域 }; int main() { Ctest test; test.Funtest(30); test.Print(); system("pause\n"); return 0; }
我們來觀察對Funtest函數(shù)的調(diào)用,test.Funtest(),在這里,我們運用了點運算符來訪問test對象的Funtest成員,然后調(diào)用它。
當(dāng)我們調(diào)用某個成員函數(shù)時,實際上是在替某個對象調(diào)用它。如果Funtest指向Ctest的成員(例如iValue),則它隱式地指向調(diào)用該函數(shù)的對象的成員。
成員函數(shù)通過一個名為this的額外的隱式參數(shù)來訪問調(diào)用它的那個對象。當(dāng)我們調(diào)用那個函數(shù)時,用請求該函數(shù)的對象地址初始化this.例如:如果調(diào)用
test.Funtest(),則編譯器負(fù)責(zé)把test的地址傳遞給Funtest的隱式形參this??梢缘葍r的認(rèn)為編譯器將該調(diào)用重寫成了如下形式:
//此處只用于說明調(diào)用成員函數(shù)實際執(zhí)行過程 Ctest::Funtest(&test)
在成員函數(shù)內(nèi)部,我們可以直接使用調(diào)用該函數(shù)的成員,而無需通過成員訪問運算符來做到,因為this指針?biāo)傅恼沁@個對象。任何對類成員的直接訪問都 被看做是this指針的隱式引用,上面的程序可認(rèn)為是this->iValue.
this形參是隱式定義的,實際上,任何自定義名為this的參數(shù)或變量的行為都是非法的.所以,F(xiàn)untest函數(shù)的定義相當(dāng)于是
void Funtest(Ctest *const this,int *iVlue) { this->_iValue = iValue; }
this是一個常量指針,不允許改變this中保存的地址
this指針的兩種傳參方式:
1.參數(shù)壓棧:當(dāng)成員函數(shù)的參數(shù)可變時,遵循_cdecl調(diào)用約定
2.ecx寄存器:當(dāng)成員函數(shù)的參數(shù)固定時,這時遵循_thiscall調(diào)用約定。
當(dāng)this指針為NULL時編譯器可編譯通過
class Ctest { public: void Funtest() {} } int main() { Ctest *p = NULL; p->Funtest(); }
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
C語言 function recursion函數(shù)遞歸詳解
遞歸指的是在函數(shù)的定義中使用函數(shù)自身的方法,舉個例子: 從前有座山,山里有座廟,廟里有個老和尚,正在給小和尚講故事呢!故事是什么呢?"從前有座山,山里有座廟,廟里有個老和尚,正在給小和尚講故事呢!故事是什么呢?"從前有座山,山里有座廟,循環(huán)下去2021-10-10