01 C++ 程式到 C 程式的翻譯
要想理解 C++ 的 this 指標,我們先把下面的 C++ 代碼轉換成 C 的代碼
class Car
{
public:
int m_price; // 成員變數
void SetPrice(int p) // 成員函式
{
m_price = p;
}
};
int main()
{
Car car;
car.SetPrice(20000); // 給car物件m_price成員變數賦值
return 0;
}
C 語言是沒有類定義的class關鍵詞,但是有跟class類似的定義,那就是結構體struct,
m_price變數是Car類的成員變數,那么我們可以把Car類和成員變數翻譯成如下的 C 代碼:
// 結構體Car
struct Car
{
// price變數是屬于Car結構體這個域里的變數
int price;
};
SetPrice函式是Car類的成員函式,但是 C 程式里是沒有成員函式這種概念的,所以只能把成員函式翻譯成全域的函式:
// 引數1:結構體Car的指標
// 引數2:要設定的價格變數
void SetPrice(struct Car* this, int p)
{
this->price = p; // 將傳入的Car結構體的price變數賦值
}
為什么要加個 this 的指標呢?我們繼續往下看,
在這里我們把上面main函式下面的 C++ 程式翻譯 C 程式是這樣的:
int main()
{
struct Car car;
SetPrice( &car, 20000);
return 0;
}
所以最終把上述的 C++程式 轉換成C 程式的代碼如下:
struct Car
{
int price;
};
void SetPrice(struct Car* this, int p)
{
this->price = p;
}
int main()
{
struct Car car;
SetPrice( &car, 20000); // 給car結構體的price變數賦值
return 0;
}
02 this指標的作用
其作用就是指向成員函式所作用的物件,
所以非靜態成員函式中可以直接使用 this 來代表指向該函式作用的物件的指標,
#include <iostream>
class Car
{
public:
int m_price;
void PrintPrice()
{
std::cout << m_price << std::endl;
}
void SetPrice(int p)
{
this->m_price = p; // 等價于 m_price = p;
this->PrintPrice();// 等價于 PrintPrice();
}
Car GetCar()
{
return *this; // 回傳該函式作用的物件
}
};
int main(void)
{
Car car1, car2;
car1.SetPrice(20000);
// GetCar()成員函式回傳所作用的car1物件,所把回傳的car1賦值給了car2
car2 = car1.GetCar();
car2.PrintPrice();
return 0;
}
輸出結果:
20000
20000
接下來我們下面的代碼,你覺得輸出結果是什么呢?會出錯嗎?
class A
{
int i;
public:
void Hello() { cout << "hello" << endl; }
};
int main()
{
A * p = NULL;
p->Hello(); //結果會怎樣?
}
答案是正常輸出hello,你可能會好奇明明 p 指標是空的,不應該是會程式奔潰嗎?別著急,我們先把上面的代碼轉換C程式,就能理解為什么能正常運行了,
void Hello() { cout << "hello" << endl; }
# 成員函式相當于如下形式:
void Hello(A * this ) { cout << "hello" << endl; }
p->Hello();
# 執行Hello()形式相當于:
Hello(p);
所以,實際上每個成員函式的第一個引數默認都有個指向物件的 this 指標,上述情況下如果該指向的物件是空,相當于成員函式的第一個引數是NULL,那么只要成員函式沒有使用到成員變數,也是可以正常執行,
下面這份代碼執行時,就會奔潰了,因為this指標是空的,使用了 空的指標指向了成員變數i,程式就會奔潰,
class A
{
int i;
public:
void Hello() { cout << i << "hello" << endl; }
// ->> void Hello(A * this ) { cout << this->i << "hello" << endl; }
};
int main()
{
A * p = NULL;
p->Hello(); // ->> Hello(p);
}
03 this指標和靜態成員函式
靜態成員函式是不能使用 this 指標,因為靜態成員函式相當于是共享的變數,不屬于某個物件的變數,
04 小結
-
通過將C++程式翻譯成C程式的方式,來理解 this 指標,其作用就是指向非靜態成員函式所作用的物件,每個成員函式的第一個引數實際上都是有個默認 this 指標引數,
-
靜態成員函式是無法使用this指標,
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/84920.html
標籤:C++
上一篇:個人專案開源之c++基于epoll實作高并發游戲盒子(服務端+客戶端)源代碼
下一篇:C++ 成員物件和封閉類

