this指針只能在一個類的成員函數中調用,它表示當前對象的地址。下面是一個例子: void Date::setMonth( int mn ) { month = mn; // 這三句是等價的 this->month = mn; (*this).month = mn; } 1. this只能在成員函數中使用。 全局函數,靜態函數都不能使用this。 實際上,成員函數默認第一個參數爲T* const register this。 如: class A{public: int func(int p){}}; 其中,func的原型在編譯器看來應該是: int func(A* const register this, int p); 2. 因而可知,this在成員函數的開始前構造的,在成員的結束後清除。 這個生命週期同任一個函數的參數是同樣的,沒有任何區別。 當調用一個類的成員函數時,編譯器將類的指針做爲函數的this參數傳遞進去。如: A a; a.func(10); 此處,編譯器將會編譯成: A::func(&a, 10); 嗯,看起來和靜態函數沒差異,對嗎?不過,區別仍是有的。編譯器一般會對this指針作一些優化的,所以,this指針的傳遞效率比較高--如vc一般是經過ecx寄存器來傳遞this參數。 3. 回答 #1:this指針是何時建立的? this在成員函數的開始執行前構造的,在成員的執行結束後清除。 #2:this指針存放在何處? 堆,棧,全局變量,仍是其餘? this指針會因編譯器不一樣,而放置的位置不一樣。多是棧,也多是寄存器,甚至全局變量。 #3:this指針如何傳遞給類中函數的?綁定?仍是在函數參數的首參數就是this指針.那麼this指針又是如何找到類實例後函數的? this是經過函數參數的首參數來傳遞的。this指針是在調用以前生成的。類實例後的函數,沒有這個說法。類在實例化時,只分配類中的變量空間,並無爲函數分配空間。自從類的函數定義完成後,它就在那兒,不會跑的。 #4:this指針如何訪問類中變量的/? 若是不是類,而是結構的話,那麼,如何經過結構指針來訪問結構中的變量呢?若是你明白這一點的話,那就很好理解這個問題了。 在C++中,類和結構是隻有一個區別的:類的成員默認是private,而結構是public。 this是類的指針,若是換成結構,那this就是結構的指針了。 #5:咱們只有得到一個對象後,才能經過對象使用this指針,若是咱們知道一個對象this指針的位置能夠直接使用嗎? this指針只有在成員函數中才有定義。所以,你得到一個對象後,也不能經過對象使用this指針。因此,咱們也沒法知道一個對象的this指針的位置(只有在成員函數裏纔有this指針的位置)。固然,在成員函數裏,你是能夠知道this指針的位置的(能夠&this得到),也能夠直接使用的。 #6:每一個類編譯後,是否建立一個類中函數表保存函數指針,以便用來調用函數? 普通的類函數(不管是成員函數,仍是靜態函數),都不會建立一個函數表來保存函數指針的。只有虛函數纔會被放到函數表中。 可是,既使是虛函數,若是編譯器能明確知道調用的是哪一個函數,編譯器就不會經過函數表中的指針來間接調用,而是會直接調用該函數。 # 7:這些編譯器如何作到的?8:可否模擬實現? 知道原理後,這兩個問題就很容易理解了。 其實,模擬實現this的調用,在不少場合下,不少人都作過。 例如,系統回調函數。系統回調函數有不少,如定時,線程啊什麼的。 舉一個線程的例子: 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 ); } 這裏就是定義一個靜態函數來模擬成員函數。 也有許多C語言寫的程序,模擬了類的實現。如freetype庫等等。 其實,有用過C語言的人,大多都模擬過。只是當時沒有明確的概念罷了。 如: typedef struct student{ int age; int no; int scores; }Student; void initStudent(Student* pstudent); void addScore(Student* pstudent, int score); ... 若是你把 pstudent改爲this,那就同樣了。 它至關於: class Student{ public: int age; int no; int scores; void initStudent(); void addScore(int score); } const常量能夠有物理存放的空間,所以是能夠取地址的 ///this指針是在建立對象前建立. this指針放在棧上,在編譯時刻已經肯定. 而且當一個對象建立後,而且運行整個程序運行期間只有一個this指針.轉!http://blog.csdn.net/guirenwang/article/details/2611355