1. 程式人生 > >c++中this指標的理解(轉載:苦澀的茶 ——產品開發 C++類中this指標的理解)

c++中this指標的理解(轉載:苦澀的茶 ——產品開發 C++類中this指標的理解)

先要理解class的意思。class應該理解為一種型別,象int,char一樣,是使用者自定義的型別。用這個型別可以來宣告一個變數,比如int x, myclass my等等。這樣就像變數x具有int型別一樣,變數my具有myclass型別。理解了這個,就好解釋this了,my裡的this 就是指向my的指標。如果還有一個變數myclass mz,mz的this就是指向mz的指標。 這樣就很容易理解this 的型別應該是myclass *,而對其的解引用*this就應該是一個myclass型別的變數。

通常在class定義時要用到型別變數自身時,因為這時候還不知道變數名(為了通用也不可能固定實際的變數名),就用this這樣的指標來使用變數自身。 

1. this指標的用處:

一個物件的this指標並不是物件本身的一部分,不會影響sizeof(物件)的結果。

this作用域是在類內部,當在類的非靜態成員函式中訪問類的非靜態成員的時候,編譯器會自動將物件本身的地址作為一個隱含引數傳遞給函式。也就是說,即使你沒有寫上this指標,編譯器在編譯的時候也是加上this的,它作為非靜態成員函式的隱含形參,對各成員的訪問均通過this進行。例如,呼叫date.SetMonth(9) <===> SetMonth(&date, 9),this幫助完成了這一轉換 .

在成員函式內部,我們可以直接使用呼叫該函式的物件的成員,而無需通過成員訪問運算子來做到這一點,因為this所指的正是這個物件。任何對類成員的直接訪問都被看成this的隱式使用。

this的目的總是指向這個物件,所以this是一個常量指標,我們不允許改變this中儲存的地址

2. this指標的使用:

一種情況就是,在類的非靜態成員函式中返回類物件本身的時候,直接使用 return *this;另外一種情況是當引數與成員變數名相同時,如this->n = n (不能寫成n = n)。 

3. this指標程式示例:

this指標是存在與類的成員函式中,指向被呼叫函式所在的類例項的地址。

根據以下程式來說明this指標

#include<iostream.h>
class Point
{ 
  int x, y;
public:
  Point(int a, int b) { x=a; y=b;}
  Void MovePoint( int a, int b){ x+=a; y+=b;}
  Void print(){ cout<<"x="<<x<<"y="<<y<<endl;}
};
void main( )
{
   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是一個指標,它時時刻刻指向你這個例項本身。

this指標基礎介紹

=================this指標的由來====================

      一個學生可以有多本書一樣,而這些書都是屬於這個同學的;同理,如果有很多個同學在一起,那麼為了確定他們的書不要拿混淆了,最好的辦法我想應該就是每個同學都在自己的書上寫上名字,這樣肯定就不會拿錯了。

      同理,一個物件的多個成員就可看作是這個物件所擁有的書;而在很多個物件中間,我們為了證明某個成員是自己的成員,而不是其他物件的成員,我們同樣需要給這些成員取上名字。在C++中,我們利用this指標幫助物件做到這一點,this指標記錄每個物件的記憶體地址,然後通過運算子->訪問該物件的成員。

=================this指標作用示例====================

      二話不說!我們通過一個程式來體現this指標的實際用處:

#include <iostream>
using namespace std;
 
class A
{
public:
    int get() const{return i;}
    void set(int x){this->i=x;cout<<"this指標儲存的記憶體地址為:"<<this<<endl;}
private:
    int i;
};
 
int main()
{
    A a;
    a.set(9);
    cout<<"物件a所在的記憶體地址為:"<<&a<<endl;
    cout<<"物件a所儲存的值為:"<<a.get()<<endl;
    cout<<endl;
    A b;
    b.set(999);
    cout<<"物件b所在的記憶體地址為:"<<&b<<endl;
    cout<<"物件b所儲存的值為:"<<b.get()<<endl;
    return 0;
}

這個程式的輸出如下:

 通過這個輸出結果,我們可以看到,物件a的記憶體地址和this指標的一模一樣(都是0017F7E8);而當執行到物件b的時候,它的記憶體地址又和它所對應的this指標指向的記憶體地址一模一樣了(都是0017F7DC)。這就說明了this指標變數記錄的是當前物件的記憶體地址,即this指標指向當前的物件!

      在程式的第8行,我們就用了this指標的這個屬性,即:this->i=x;這句話就表示把x的值賦值給當前的物件的私有成員函式i。

=================總結====================

      通過上面這個例子,我們可以看到this指標最大的作用就是它儲存了當前物件的地址,並且應用指標的形式指向了當前的物件。