Item M1 指標與引用的區別

2021-05-26 10:35:16 字數 1685 閱讀 8914

指標用操作符「*」和「->」,引用使用操作符「. 」,但是它們似乎有相同的功能。指標與引用都是讓你間接引用其他物件。

首先,要認識到在任何情況下都不能使用指向空值的引用。乙個引用必須總是指向某些物件。因此如果你使用乙個變數並讓它指向乙個物件,但是該變數在某些時候也可能不指向任何物件,這時你應該把變數宣告為指標,因為這樣你可以賦空值給該變數。相反,如果變數肯定指向乙個物件,例如你的設計不允許變數為空,這時你就可以把變數宣告為引用。

char *pc = 0; // 設定指標為空值

char& rc = *pc; // 讓引用指向空值

/*以上**在vs2008下生成成功,執行時出現錯誤*/

這是非常有害的,毫無疑問,結果將是不確定的。我們以後將忽略乙個引用指向空值的可能性。因為引用肯定會指向乙個物件,在c++裡,引用應被初始化。

string& rs; // 錯誤,引用必須被初始化

string s("xyzzy");

string& rs = s; // 正確,rs指向s

指標沒有這樣的限制。

string *ps; // 未初始化的指標 ,合法但危險

不存在指向空值的引用這個事實意味著使用引用的**效率比使用指標的要高。因為在使用引用之前不需要測試它的合法性。

void printdouble(const double& rd)

cout << rd; // 不需要測試rd,它

}              // 肯定指向乙個double值

相反,指標則應該總是被測試,防止其為空:

void printdouble(const double *pd)

if (pd) { // 檢查是否為null

cout << *pd;

其次,指標與引用的另乙個重要的不同是指標可以被重新賦值以指向另乙個不同的物件。但是引用則總是指向在初始化時被指定的物件,以後不能改變。

string s1("nancy");

string s2("clancy");

string& rs = s1; // rs 引用 s1

string *ps = &s1; // ps 指向 s1

rs = s2; // rs 仍舊引用s1,

// 但是 s1的值現在是

// "clancy"

ps = &s2; // ps 現在指向 s2;

// s1 沒有改變

在以下情況下你應該使用指標:

一是你考慮到存在不指向任何物件的可能(在這種情況下,你能夠設定指標為空)

二是你需要能夠在不同的時刻指向不同的物件(在這種情況下,你能改變指標的指向)。

以下情況應該使用引用:

(1)總是指向乙個物件並且一旦指向乙個物件後就不會改變指向。

(2)當你過載某個操作符時,你應該使用引用。最普通的例子是操作符。這個操作符典型的用法是返回乙個目標物件,其能被賦值。

vectorv(10); // 建立整形向量(vector),大小為10;

// 向量是乙個在標準c庫中的乙個模板(見條款m35)

v[5] = 10; // 這個被賦值的目標物件就是操作符返回的值

如果操作符返回乙個指標,那麼後乙個語句就得這樣寫:

*v[5] = 10;

但是這樣會使得v看上去象是乙個向量指標。因此你會選擇讓操作符返回乙個引用。(這有乙個有趣的例外,參見條款m30)

1 指標與引用的區別

指標 指標是位址傳遞,但其本質上是值傳遞,通常實參傳給形參時,被調函式的形參作為被調函式的區域性變數處理,即在棧中開闢了記憶體空間以存放由主調函式放進來的實參的值,從而成為了實參的乙個副本。所以進行指標傳遞時,作為實參的指標本身所存的位址值是不會變的,但指標所指位址中的內容則會根據函式的不同操作而改...

1 指標和引用的區別

1 什麼是指標?2 什麼是引用?引用 引用是乙個物件的別名,主要用於函式引數和返回值型別,符號x 表示x型別的引用。1 引用不可以為空,但指標可以為空。引用是物件的別名,引用為空 物件都不存在,怎麼可能有別名!所以定義乙個引用的時候,必須初始化。宣告指標是可以不指向任何物件,因此,使用指標之前必須做...

1 指標和引用的區別

性質上的區別 使用上的區別 引用必須要初始化且不能是null,而指標可以是null。且指標的值可以改變,引用不能改變 更像是const,常量指標的概念 有const指標,但沒有const引用 指標可以有多級 p 引用只有一級 sizeof引用 得到的是所指向的變數 物件 的大小,而 sizeof指標...