C++中this指針的用法及介紹

this指針只能在一個(gè)類的成員函數(shù)中調(diào)用,它表示當(dāng)前對(duì)象的地址。下面是一個(gè)例子:

void Date::setMonth( int mn )

{

month = mn; // 這三句是等價(jià)的

this->month = mn;

(*this).month = mn;

}

1. this只能在成員函數(shù)中使用。

全局函數(shù),靜態(tài)函數(shù)都不能使用this。

實(shí)際上,成員函數(shù)默認(rèn)第一個(gè)參數(shù)為T* const register this。

如:

class A{public: int func(int p){}};

其中,func的原型在編譯器看來應(yīng)該是: int func(A* const register this, int p);

2. 由此可見,this在成員函數(shù)的開始前構(gòu)造的,在成員的結(jié)束后清除。

這個(gè)生命周期同任一個(gè)函數(shù)的參數(shù)是一樣的,沒有任何區(qū)別。

當(dāng)調(diào)用一個(gè)類的成員函數(shù)時(shí),編譯器將類的指針作為函數(shù)的this參數(shù)傳遞進(jìn)去。如:

A a;

a.func(10);

此處,編譯器將會(huì)編譯成: A::func(&a, 10);

嗯,看起來和靜態(tài)函數(shù)沒差別,對(duì)嗎?不過,區(qū)別還是有的。編譯器通常會(huì)對(duì)this指針做一些優(yōu)化的,因此,this指針的傳遞效率比較高--如vc通常是通過ecx寄存器來傳遞this參數(shù)。

3. 回答

#1:this指針是什么時(shí)候創(chuàng)建的?

this在成員函數(shù)的開始執(zhí)行前構(gòu)造的,在成員的執(zhí)行結(jié)束后清除。

#2:this指針存放在何處? 堆,棧,全局變量,還是其他?

this指針會(huì)因編譯器不同,而放置的位置不同??赡苁菞?,也可能是寄存器,甚至全局變量。

#3:this指針如何傳遞給類中函數(shù)的?綁定?還是在函數(shù)參數(shù)的首參數(shù)就是

如何找到類實(shí)例后函數(shù)的?

this是通過函數(shù)參數(shù)的首參數(shù)來傳遞的。this指針是在調(diào)用之前生成的。類實(shí)例后的函數(shù),沒有這個(gè)說法。類在實(shí)例化時(shí),只分配類中的變量空間,并沒有為函數(shù)分配空間。自從類的函數(shù)定義完成后,它就在那兒,不會(huì)跑的。

#4:this指針如何訪問類中變量的/?

如果不是類,而是結(jié)構(gòu)的話,那么,如何通過結(jié)構(gòu)指針來訪問結(jié)構(gòu)中的變量呢?如果你明白這一點(diǎn)的話,那就很好理解這個(gè)問題了。

在C++中,類和結(jié)構(gòu)是只有一個(gè)區(qū)別的:類的成員默認(rèn)是private,而結(jié)構(gòu)是public。

this是類的指針,如果換成結(jié)構(gòu),那this就是結(jié)構(gòu)的指針了。

#5:我們只有獲得一個(gè)對(duì)象后,才能通過對(duì)象使用this指針,如果我們知道一個(gè)對(duì)象this指針的位置可以直接使用嗎?

this指針只有在成員函數(shù)中才有定義。因此,你獲得一個(gè)對(duì)象后,也不能通過對(duì)象使用this指針。所以,我們也無法知道一個(gè)對(duì)象的this指針的位置(只有在成員函數(shù)里才有this指針的位置)。當(dāng)然,在成員函數(shù)里,你是可以知道this指針的位置的(可以&this獲得),也可以直接使用的。

#6:每個(gè)類編譯后,是否創(chuàng)建一個(gè)類中函數(shù)表保存函數(shù)指針,以便用來調(diào)用函數(shù)?

普通的類函數(shù)(不論是成員函數(shù),還是靜態(tài)函數(shù)),都不會(huì)創(chuàng)建一個(gè)函數(shù)表來保存函數(shù)指針的。只有虛函數(shù)才會(huì)被放到函數(shù)表中。

但是,既使是虛函數(shù),如果編譯器能明確知道調(diào)用的是哪個(gè)函數(shù),編譯器就不會(huì)通過函數(shù)表中的指針來間接調(diào)用,而是會(huì)直接調(diào)用該函數(shù)。

# 7:這些編譯器如何做到的?8:能否模擬實(shí)現(xiàn)?

知道原理后,這兩個(gè)問題就很容易理解了。

其實(shí),模擬實(shí)現(xiàn)this的調(diào)用,在很多場(chǎng)合下,很多人都做過。

例如,系統(tǒng)回調(diào)函數(shù)。系統(tǒng)回調(diào)函數(shù)有很多,如定時(shí),線程啊什么的。

舉一個(gè)線程的例子:

class A{

int n;

public:

static void run(void* pThis){

A* this_ = (A*)pThis;

this_->process();

}

void process(){}

};

main(){

A a;

_beginthread( A::run, 0, &a );

}

這里就是定義一個(gè)靜態(tài)函數(shù)來模擬成員函數(shù)。

也有許多C語言寫的程序,模擬了類的實(shí)現(xiàn)。如freetype庫等等。

其實(shí),有用過C語言的人,大多都模擬過。只是當(dāng)時(shí)沒有明確的概念罷了。

如:

typedef struct student{

int age;

int no;

int scores;

}Student;

void initStudent(Student* pstudent);

void addScore(Student* pstudent, int score);

...

如果你把 pstudent改成this,那就一樣了。

它相當(dāng)于:

class Student{

public:

int age; int no; int scores;

void initStudent();

void addScore(int score);

}

const常量可以有物理存放的空間,因此是可以取地址的

///this指針是在創(chuàng)建對(duì)象前創(chuàng)建.

this指針放在棧上,在編譯時(shí)刻已經(jīng)確定.

并且當(dāng)一個(gè)對(duì)象創(chuàng)建后,并且運(yùn)行整個(gè)程序運(yùn)行期間只有一個(gè)this指針.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • __block和__weak修飾符的區(qū)別其實(shí)是挺明顯的:1.__block不管是ARC還是MRC模式下都可以使用,...
    LZM輪回閱讀 3,594評(píng)論 0 6
  • 1.寫一個(gè)NSString類的實(shí)現(xiàn) +(id)initWithCString:(c*****t char *)nu...
    韓七夏閱讀 3,875評(píng)論 2 37
  • C++文件 例:從文件income. in中讀入收入直到文件結(jié)束,并將收入和稅金輸出到文件tax. out。 檢查...
    SeanC52111閱讀 3,103評(píng)論 0 3
  • 指針是C語言中廣泛使用的一種數(shù)據(jù)類型。 運(yùn)用指針編程是C語言最主要的風(fēng)格之一。利用指針變量可以表示各種數(shù)據(jù)結(jié)構(gòu); ...
    朱森閱讀 3,615評(píng)論 3 44
  • 前言 把《C++ Primer》[https://book.douban.com/subject/25708312...
    尤汐Yogy閱讀 9,676評(píng)論 1 51

友情鏈接更多精彩內(nèi)容