1. 程式人生 > >C++ 中 this 指標的用法詳解

C++ 中 this 指標的用法詳解

1. this指標的用處:

一個物件的this指標並不是物件本身的一部分,不會影響sizeof(物件)的結果。this作用域是在類內部,當在類的非靜態成員函式中訪問類的非靜態成員的時候,編譯器會自動將物件本身的地址作為一個隱含引數傳遞給函式。也就是說,即使你沒有寫上this指標,編譯器在編譯的時候也是加上this的,它作為非靜態成員函式的隱含形參,對各成員的訪問均通過this進行。

例如,呼叫date.SetMonth(9) <===> SetMonth(&date, 9),this幫助完成了這一轉換 。

2. this指標的使用:

一種情況就是,在類的非靜態成員函式中返回類物件本身的時候,直接使用 return *this

;另外一種情況是當引數與成員變數名相同時,如this->n = n (不能寫成n = n)。

3. this指標程式示例:

this指標存在於類的成員函式中,指向被呼叫函式所在的類例項的地址。   根據以下程式來說明this指標

123456789101112 #include   classPoint  {  intx,y;  public:  Point(inta,intb){x=a;y=b;}  voidMovePoint(inta,intb){x+=a;y+=b;}  voidprint(){cout<<"x="<  };  voidmain()  {  Point point1(10,10);  point1.MovePoint(2,2);  point1.print();  }

當物件point1

呼叫MovePoint(2,2)函式時,即將point1物件的地址傳遞給了this指標。

MovePoint函式的原型應該是 void MovePoint( Point *this, int a, int b);第一個引數是指向該類物件的一個指標,我們在定義成員函式時沒看見是因為這個引數在類中是隱含的。這樣point1的地址傳遞給了this,所以在MovePoint函式中便顯式的寫成:

void MovePoint(int a, int b) { this->x +=a; this-> y+= b;}

即可以知道,point1呼叫該函式後,也就是point1的資料成員被呼叫並更新了值。

即該函式過程可寫成 point1.x+= a; point1. y + = b;

4. 關於this指標的一個經典回答:

當你進入一個房子後,

你可以看見桌子、椅子、地板等,

但是房子你是看不到全貌了。

對於一個類的例項來說,

你可以看到它的成員函式、成員變數,

但是例項本身呢?

this是一個指標,它時時刻刻指向你這個例項本身

5. 類的this指標有以下特點:

1this只能在成員函式中使用。

全域性函式、靜態函式都不能使用this.

實際上,成員函式預設第一個引數為T * const this

如:

1234567 classA{public:intfunc(intp){}};

其中,func的原型在編譯器看來應該是:

int func(A * const this,int p);

2)由此可見,this在成員函式的開始前構造,在成員函式的結束後清除。

這個生命週期同任何一個函式的引數是一樣的,沒有任何區別。

當呼叫一個類的成員函式時,編譯器將類的指標作為函式的this引數傳遞進去。如:

A a;
a.func(10);

此處,編譯器將會編譯成:

A::func(&a,10);

看起來和靜態函式沒差別,對嗎?不過,區別還是有的。編譯器通常會對this指標做一些優化,因此,this指標的傳遞效率比較高VC通常是通過ecx暫存器傳遞this引數的。

3)幾個this指標的易混問題。

A. this指標是什麼時候建立的?

this在成員函式的開始執行前構造,在成員的執行結束後清除。

但是如果class或者struct裡面沒有方法的話,它們是沒有建構函式的,只能當做Cstruct使用。採用 TYPE xx的方式定義的話,在棧裡分配記憶體,這時候this指標的值就是這塊記憶體的地址。採用new的方式 建立物件的話,在堆裡分配記憶體,new操作符通過eax返回分配 的地址,然後設定給指標變數。之後去調 用建構函式(如果有建構函式的話),這時將這個記憶體塊的地址傳給ecx,之後建構函式裡面怎麼處理請 看上面的回答。

B. this指標存放在何處?堆、棧、全域性變數,還是其他?

this指標會因編譯器不同而有不同的放置位置。可能是棧,也可能是暫存器,甚至全域性變數。在彙編級 別裡面,一個值只會以3種形式出現:立即數、暫存器值和記憶體變數值。不是存放在暫存器就是存放在內 存中,它們並不是和高階語言變數對應的。

C. this指標是如何傳遞類中的函式的?繫結?還是在函式引數的首引數就是this指標?那麼,this指標 又是如何找到“類例項後函式的”?

大多數編譯器通過ecx暫存器傳遞this指標。事實上,這也是一個潛規則。一般來說,不同編譯器都會遵從一致的傳參規則,否則不同編譯器產生的obj就無法匹配了。

call之前,編譯器會把對應的物件地址放到eax中。this是通過函式引數的首參來傳遞的。this指標在呼叫之前生成,至於“類例項後函式”,沒有這個說法。類在例項化時,只分配類中的變數空間,並沒有為函式分配空間。自從類的函式定義完成後,它就在那兒,不會跑的。

D. this指標是如何訪問類中的變數的?

如果不是類,而是結構體的話,那麼,如何通過結構指標來訪問結構中的變數呢?如果你明白這一點的話,就很容易理解這個問題了

C++ ,類和結構是隻有一個區別的:類的成員預設是private,而結構是public

this是類的指標,如果換成結構,那this就是結構的指標了。

E. 我們只有獲得一個物件後,才能通過物件使用this指標。如果我們知道一個物件this指標的位置,可以直接使用嗎?

this指標只有在成員函式中才有定義。因此,你獲得一個物件後,也不能通過物件使用this指標。所以,我們無法知道一個物件的this指標的位置(只有在成員函式裡才有this指標的位置)。當然,在成員函式裡,你是可以知道this指標的位置的(可以通過&this獲得),也可以直接使用它。

F. 每個類編譯後,是否建立一個類中函式表儲存函式指標,以便用來呼叫函式?

普通的類函式(不論是成員函式,還是靜態函式)都不會建立一個函式表來儲存函式指標。只有虛擬函式才會被放到函式表中。但是,即使是虛擬函式,如果編譯器能明確知道呼叫的是哪個函式,編譯器就不會通過函式表中的指標來間接呼叫,而是會直接呼叫該函式。

相關推薦

C++this指標

成員函式中this是指向正在呼叫該函式的物件,this指正在建立物件內部的成員。同一個類中的函式可以通過this相互呼叫,普通函式不能通過this呼叫建構函式,但建構函式可以通過this訪問普通函式!.h檔案ifndef TEACHER_H_#define TEACHER_H

C#HttpWebRequest的用法

網站 default 編碼方式 對數 c# toarray collect acc like 本文實例講述了C#中HttpWebRequest的用法。分享給大家供大家參考。具體如下: HttpWebRequest類主要利用HTTP 協議和服務器交互,通常是通過 GET 和

C++的map用法

時間 占用 sort函數 數組 例程 通道 組織 sso 查找 Map是 STL的一個關聯容器,它提供一對一(其中第一個可以稱為關鍵字,每個關鍵字只能在map中出現一次,第二個可能稱為該關鍵字的值)的數據 處理能力,由 於這個特性,它完成有可能在我們處理一對一數據的

【轉載】 c++static的用法

ostream 並不會 style 轉載 程序員 都是 note 每次 reference 出處: http://blog.csdn.net/majianfei1023/article/details/45290467 C 語言的 static 關鍵字有三種(具體來說是

C#string.format用法

個數 date 其中 位置 tr1 bsp 位數 數值 日期格式化 tring.Format 方法的幾種定義: String.Format (String, Object) 將指定的 String 中的格式項替換為指定的 Object 實例的值的文本等效項。String.F

c++static的用法

C 語言的 static 關鍵字有三種(具體來說是兩種)用途: 1. 靜態區域性變數:用於函式體內部修飾變數,這種變數的生存期長於該函式。 int foo(){ static int i = 1; // note:1 //int i = 1; // not

c++c_str()的用法

//標準庫的string類提供了三個成員函式來從一個string得到c型別的字元陣列 //主要介紹c_str //c_str():生成一個const char*指標,指向以空字元終止的陣列。 //這個陣列應該是string類內部的陣列 #include <iostre

c++map的用法

說明下面我都以 map<string,   int> 型別來舉例。 一、定義          (1) map<string,   int>   Map;     (2) 或者是:typedef   map<string,int>  

C++set的用法

C++中set的用法 set的特性是,所有元素都會根據元素的鍵值自動排序,set的元素不像map那樣可以同時擁有實值(value)和鍵值(key),set元素的鍵值就是實值,實值就是鍵值。set不允許兩個元素有相同的鍵值。 set的各成員函式列表如下:

C++ this指標 C++this指標用法

C++中this指標的用法詳解   轉自:http://blog.chinaunix.net/uid-21411227-id-1826942.html 1. this指標的用處:   一個物件的this指標並不是物件本身的一部分,不會影響sizeof(物件)的結果

c++this指標用法

為什麼引入this指標?     最簡單的應用場景就是:當我們在類中定義了一個變數,同時在類成員函式中定義了同一變數時,也就是說變數名重複時,但是我們想使用類中定義的變數,這個時候我們該怎麼辦呢?這個時候就是this指標大顯身手的時候了。為此我們引入this指標

C++this指標的作用以及用法

為什麼引用this指標? 當我們在類中定義了一個變數,同時又在類成員函式中定義了同一個變數時,也就是變數名重複時,但是我們要想使用類中的定義的變數,此時就需要this指標了。 1.this指標的作用 指標存在於類的成員函式中,指向被呼叫函式類例項的地址。  一個物件的thi

C++ this 指標用法

1. this指標的用處: 一個物件的this指標並不是物件本身的一部分,不會影響sizeof(物件)的結果。this作用域是在類內部,當在類的非靜態成員函式中訪問類的非靜態成員的時候,編譯器會自動將物件本身的地址作為一個隱含引數傳遞給函式。也就是說,即使你沒有寫上

C++this指標的理解和用法

關於this指標的一個精典回答: 當你進入一個房子後,你可以看見桌子、椅子、地板等,但是房子你是看不到全貌了。對於一個類的例項來說,你可以看到它的成員函式、成員變數,但是例項本身呢?this是一個指標,它時時刻刻指向你這個例項本身。 個人理解: (ps:class類就好比這

[c++] vectorinsert()的用法

iterator insert( iterator loc, const TYPE &val ); void insert( iterator loc, size_type num, const TYPE &val ); void insert( itera

JavaScriptreturn的用法

style 返回 www log tle blog 意思 charset fun 1、定義:return 從字面上的看就是返回,官方定義return語句將終止當前函數並返回當前函數的值,可以看下下面的示例代碼: <!DOCTYPE html><html l

java的instanceof用法

定義 xtend print 繼承 interface 參數 保留 如果 ack   instanceof是Java的一個二元操作符(運算符),也是Java的保留關鍵字。它的作用是判斷其左邊對象是否為其右邊類的實例,返回的是boolean類型的數據。用它來判斷某個對象是否是

第149天:javascriptthis的指向

doc ava 常見 每一個 document () 學習 知識 對象 js中的this指向十分重要,了解js中this指向是每一個學習js的人必學的知識點,今天沒事,正好總結了js中this的常見用法,喜歡的可以看看: 1、全局作用域或者普通函數中this指向全局對象wi

c#this用法及作用

sys 靜態成員 mes 成員 成員方法 read 訪問 write stat 在C#中, 1. this關鍵字代表當前實例,我們可以用this.來調用當前實例的成員方法,變量,屬性,字段等; 2. 也可以用this來做為參數狀當前實例做為參

C++的多態

C++ 多態 [TOC]#虛函數和多態 虛函數 定義:類的成員函數前面加virtual關鍵字,則這個成員函數稱為虛函數。 ###代碼示例: class Person { public: virtual void Buyticket() { cout << "