今天做c++ primer的習題,前面關於引用的部分,又傻了。哎,補基礎吧。收集了一下別人的講解。
(1)在實際的程式中,引用主要被用做函式的形式引數--通常將類物件傳遞給乙個函式.引用必須初始化.但是用物件的位址初始化引用是錯誤的,我們可以定義乙個指標引用。
1 int ival = 1092;
2 int &re = ival; //ok
3 int &re2 = &ival; //錯誤
4 int *pi = &ival;
5 int *&pi2 = pi; //ok 指標的引用,太**了。
關於指標的引用,在這裡有詳細解答
(2)一旦引用已經定義,它就不能再指向其他的物件.這就是為什麼它要被初始化的原因。
(3)const
引用可以用不同型別的物件初始化(只要能從一種型別轉換到另一種型別即可),也可以是不可定址的值,如文字常量。例如
double dval = 3.14159;
//下3行僅對const引用才是合法的
const int &ir = 1024;
const int &ir2 = dval;
const double &dr = dval + 1.0;
上面,同樣的初始化對於非const引用是不合法的,將導致編譯錯誤。原因有些微妙,需要適當做些解釋。
引用在內部存放的是乙個物件的位址,它是該物件的別名。對於不可定址的值,如文字常量,以及不同型別的物件,編譯器為了實現引用,必須生成乙個臨時物件,引用實際上指向該物件,但使用者不能訪問它。
例如:
double dval = 23;
const int &ri = dval;
編譯器將其轉換為:
int tmp = dval; // double -> int
const int &ri = tmp;
同理:上面**
double dval = 3.14159;
//下3行僅對const引用才是合法的
const int &ir = 1024;
const int &ir2 = dval;
const double &dr = dval + 1.0;
內部轉化為:
double dval = 3.14159;
//不可定址,文字常量
int tmp1 = 1024;
const int &ir = tmp1;
//不同型別
int tmp2 = dval;//double -> int
const int &ir2 = tmp2;
//另一種情況,不可定址
double t*** = dval + 1.0;
const double &dr = t***;
(4)不允許非const引用指向需要臨時物件的物件或值,即,編譯器產生臨時變數的時候引用必須為const!!!!切記!!
int iv = 100;
int *&pir = &iv;//錯誤,非const引用對需要臨時物件的引用
int *const &pir = &iv;//ok
const int ival = 1024;
int *&pi_ref = &ival; //錯誤,非const引用是非法的
const int *&pi_ref = &ival; //錯誤,需要臨時變數,且引用的是指標,而pi_ref是乙個非常量指標
const int * const &pi_ref = &ival; //正確
//補充
const int *p = &ival;
const int *&pi_ref = p; //正確
(5)********
對於const int *const & pi_ref = &iva;具體的分析如下:*********
1.不允許非const引用指向需要臨時物件的物件或值
int a = 2;
int &ref1 = a;// ok.有過渡變數。
const int &ref2 = 2;// ok.編譯器產生臨時變數,需要const引用
2.位址值是不可定址的值
int * const &ref3 = &a; // ok;
3.於是,用const物件的位址來初始化乙個指向指標的引用
const int b = 23;
const int *p = &b;
const int *& ref4 = p;
const int *const & ref5 = &b; //ok
const引用的語義到底是什麼?
最後,我們可能仍然不明白const引用的這個const的語義是什麼
const引用表示,試圖通過此引用去(間接)改變其引用的物件的值時,編譯器會報錯!
這並意味著,此引用所引用的物件也因此變成const型別了。我們仍然可以改變其指向物件的值,只是不通過引用
下面是乙個簡單的例子:
#include using namespace std;
int main()
其中第10行,如果我們通過ir來改變val的值,編譯時會出錯。但是我們仍然可以通過val直接改變其值(第9行)
總結:const引用只是表明,保證不會通過此引用間接的改變被引用的物件!
另外,const既可以放到型別前又可以放到型別後面,放型別後比較容易理解:
string const *t1;
const string *t1;
typedef string* pstring;string s;
const pstring cstr1 = &s;就出錯了
但是放在型別後面不會出錯:
pstring const cstr2 = &s;
C const引用詳解
文章 http blog.csdn.net k2eats archive 2008 06 12 2541790.aspx 1 在實際的程式中,引用主要被用做函式的形式引數 通常將類物件傳遞給乙個函式 引用必須初始化 但是用物件的位址初始化引用是錯誤的,我們可以定義乙個指標引用。1int ival 1...
C const引用詳解
文章 1 在實際的程式中,引用主要被用做函式的形式引數 通常將類物件傳遞給乙個函式.引用必須初始化.但是用物件的位址初始化引用是錯誤的,我們可以定義乙個指標引用。1 intival 1092 2 int re ival ok 3 int re2 ival 錯誤 4 int pi ival 5 int...
C const引用 臨時變數 引用引數
c 引用 臨時變數 引用引數和const引用 如果實參與引用引數不匹配,c 將生成臨時變數。如果引用引數是const,則編譯器在下面兩種情況下生成臨時變數 實參型別是正確的,但不是左值 實參型別不正確,但可以轉換為正確的型別 左值引數是可被引用的資料物件,例如,變數 陣列元素 結構成員 引用和被解除...