CPP中的this指针
this指針是類的一個自動生成、自動隱蔽的私有成員,它存在于類的非靜態成員中,指向被調用函數所在的對象。
全局僅有一個this指針,當一個對象被創建時,this指針就存放指向對象數據的首地址。
class Ctest
{
public:
??? void Funtest(int iValue)
??? {
??????? _iValue = iValue;
??? }
??? void Print()
??? {
??????? cout << _iValue << endl;
??? }
private:
??? int _iValue;//調用私有變量只能用公有成員接收,成員變量在類中具有全局作用域
};
int main()
{
??? Ctest test;
??? test.Funtest(30);
??? test.Print();
??? system("pause\n");
??? return 0;
}
??
我們來觀察對Funtest函數的調用,test.Funtest(),在這里,我們運用了點運算符來訪問test對象的Funtest成員,然后調用它。
當我們調用某個成員函數時,實際上是在替某個對象調用它。如果Funtest指向Ctest的成員(例如iValue),則它隱式地指向調用該函數的對象的成員。
成員函數通過一個名為this的額外的隱式參數來訪問調用它的那個對象。當我們調用那個函數時,用請求該函數的對象地址初始化this.例如:如果調用
test.Funtest(),則編譯器負責把test的地址傳遞給Funtest的隱式形參this。可以等價的認為編譯器將該調用重寫成了如下形式:
//此處只用于說明調用成員函數實際執行過程
Ctest::Funtest(&test)
??? 1
??? 2
我們可在反匯編中查看調用過程
在成員函數內部,我們可以直接使用調用該函數的成員,而無需通過成員訪問運算符來做到,因為this指針所指的正是這個對象。任何對類成員的直接訪問都
被看做是this指針的隱式引用,上面的程序可認為是this->iValue.
this形參是隱式定義的,實際上,任何自定義名為this的參數或變量的行為都是非法的.所以,Funtest函數的定義相當于是
void Funtest(Ctest *const this,int *iVlue)
{
? this->_iValue = iValue;
}
??? 1
??? 2
??? 3
??? 4
this是一個常量指針,不允許改變this中保存的地址
this指針的兩種傳參方式:
1.參數壓棧:當成員函數的參數可變時,遵循_cdecl調用約定
2.ecx寄存器:當成員函數的參數固定時,這時遵循_thiscall調用約定。
當this指針為NULL時編譯器可編譯通過
class Ctest
{
? public:
??? void Funtest()
{}
}
?int main()
{
?Ctest *p = NULL;
?p->Funtest();
}
————————————————
版權聲明:本文為CSDN博主「ChaseRaod」的原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/ChaseRaod/article/details/61617777
總結
以上是生活随笔為你收集整理的CPP中的this指针的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: [C++] this指针
- 下一篇: 常函数及其由来