指針和引用的區別 指針和引用的區別描述錯誤的是


指針和引用的區別 指針和引用的區別描述錯誤的是

文章插圖
大家好,小問來為大家解答以上問題 。指針和引用的區別描述錯誤的是,指針和引用的區別這個很多人還不知道,現在讓我們一起來看看吧!
1、指針與引用看上去完全不同(指針用操作符“*”和“->”,引用使用操作符“. ”),但是它們似乎有相同的功能 。
2、指針與引用都是讓你間接引用其他對象 。
【指針和引用的區別 指針和引用的區別描述錯誤的是】3、你如何決定在什么時候使用指針,在什么時候使用引用呢?首先,要認識到在任何情況下都不能使用指向空值的引用 。
4、一個引用必須總是指向某些對象 。
5、因此如果你使用一個變量并讓它指向一個對象,但是該變量在某些時候也可能不指向任何對象 , 這時你應該把變量聲明為指針,因為這樣你可以賦空值給該變量 。
6、相反,如果變量肯定指向一個對象,例如你的設計不允許變量為空,這時你就可以把變量聲明為引用 。
7、“但是,請等一下”,你懷疑地問,“這樣的代碼會產生什么樣的后果?”char *pc = 0; // 設置指針為空值char& rc = *pc; // 讓引用指向空值這是非常有害的,毫無疑問 。
8、結果將是不確定的(編譯器能產生一些輸出 , 導致任何事情都有可能發生) 。
9、應該躲開寫出這樣代碼的人,除非他們同意改正錯誤 。
10、如果你擔心這樣的代碼會出現在你的軟件里 , 那么你最好完全避免使用引用,要不然就去讓更優秀的程序員去做 。
11、我們以后將忽略一個引用指向空值的可能性 。
12、因為引用肯定會指向一個對象,在C++里 , 引用應被初始化 。
13、string& rs; // 錯誤,引用必須被初始化string s("xyzzy");string& rs = s; // 正確,rs指向s指針沒有這樣的限制 。
14、string *ps; // 未初始化的指針// 合法但危險不存在指向空值的引用這個事實意味著使用引用的代碼效率比使用指針的要高 。
15、因為在使用引用之前不需要測試它的合法性 。
16、void printDouble(const double& rd){cout << rd; // 不需要測試rd,它} // 肯定指向一個double值相反,指針則應該總是被測試 , 防止其為空:void printDouble(const double *pd){if (pd) { // 檢查是否為NULLcout << *pd;}}指針與引用的另一個重要的不同是指針可以被重新賦值以指向另一個不同的對象 。
17、但是引用則總是指向在初始化時被指定的對象,以后不能改變 。
18、string s1("Nancy");string s2("Clancy");string& rs = s1; // rs 引用 s1string *ps = &s1; // ps 指向 s1rs = s2; // rs 仍舊引用s1,// 但是 s1的值現在是// "Clancy"ps = &s2; // ps 現在指向 s2;// s1 沒有改變總的來說,在以下情況下你應該使用指針,一是你考慮到存在不指向任何對象的可能(在這種情況下,你能夠設置指針為空),二是你需要能夠在不同的時刻指向不同的對象(在這種情況下,你能改變指針的指向) 。
19、如果總是指向一個對象并且一旦指向一個對象后就不會改變指向,那么你應該使用引用 。
20、還有一種情況,就是當你重載某個操作符時,你應該使用引用 。
21、最普通的例子是操作符[] 。
22、這個操作符典型的用法是返回一個目標對象,其能被賦值 。
23、vector v(10); // 建立整形向量(vector),大小為10;// 向量是一個在標準C庫中的一個模板(見條款M35)v[5] = 10; // 這個被賦值的目標對象就是操作符[]返回的值如果操作符[]返回一個指針,那么后一個語句就得這樣寫:*v[5] = 10;但是這樣會使得v看上去象是一個向量指針 。
24、因此你會選擇讓操作符返回一個引用 。
25、(這有一個有趣的例外 , 參見條款M30)當你知道你必須指向一個對象并且不想改變其指向時,或者在重載操作符并為防止不必要的語義誤解時,你不應該使用指針 。
26、而在除此之外的其他情況下,則應使用指針 。
27、
以上就是【指針和引用的區別描述錯誤的是,指針和引用的區別】相關內容 。

    推薦閱讀