• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 10  文章 - 0  trackbacks - 0
            <2008年12月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            靜心學(xué)習(xí),好好珍惜身邊的人。

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            •  

            積分與排名

            • 積分 - 3723
            • 排名 - 1725

            最新評論

            閱讀排行榜

            評論排行榜

            C++引用與const引用

            (1)在實際的程序中,引用主要被用做函數(shù)的形式參數(shù)--通常將類對象傳遞給一個函數(shù).
            引用必須初始化. 但是用對象的地址初始化引用是錯誤的,我們可以定義一個指針引用.

             

            1 int ival = 1092;
            2 int &re = ival;   //ok
            3 int &re2 = &ival;   //錯誤
            4 int *pi = &ival;
            5 int *&pi2 = pi;   //ok

            (2)一旦引用已經(jīng)定義,它就不能再指向其他的對象.這就是為什么它要被初始化的原因.

            (3)const引用可以用不同類型的對象初始化(只要能從一種類型轉(zhuǎn)換到另一種類型即可),也可以是不可尋址的值,如文字常量。例如

            double dval = 3.14159;
            //下3行僅對const引用才是合法的
            const int &ir = 1024;
            const int &ir2 = dval;
            const double &dr = dval + 1.0;

            上面,同樣的初始化對于非const引用是不合法的,將導(dǎo)致編譯錯誤。原因有些微妙,需要適當(dāng)做些解釋。
            引用在內(nèi)部存放的是一個對象的地址,它是該對象的別名。對于不可尋址的值,如文字常量,以及不同
            型的對象,編譯器為了實現(xiàn)引用,必須生成一個臨時對象,引用時間上指向該對象,但用戶不能訪問它。
            例如: 

            double dval = 23;
            const int &ri = dval;

            編譯器將其轉(zhuǎn)換為:

            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;

            內(nèi)部轉(zhuǎn)化為:

            double dval = 3.14159;

            //不可尋址,文字常量
            int tmp1 = 1024;
            const int &ir = tmp1;

            //不同類型
            int tmp2 = dval;//double -> int
            const int &ir2 = tmp2;

            //另一種情況,不可尋址
            double tmp3 = dval + 1.0;
            const double &dr = tmp3;

            (4)不允許非const引用指向需要臨時對象的對象或值,即,編譯器產(chǎn)生臨時變量的時候引用必須為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;  //正確
             



             ********對于const int *const & pi_ref = &iva; 具體的分析如下:*********

            1.不允許非const引用指向需要臨時對象的對象或值

            int a = 2;
            int &ref1 = a;// OK.有過渡變量。 
            const int &ref2 = 2;// OK.編譯器產(chǎn)生臨時變量,需要const引用


            2.地址值是不可尋址的值


            int * const &ref3 = &a;   // OK;

            3.于是,用const對象的地址來初始化一個指向指針的引用

                const int b = 23;
                
            const int *= &b; 
                
            const int *& ref4 = p;
                
            const int *const & ref5 = &b;   //OK

            const引用的語義到底是什么?

            最后,我們可能仍然不明白const引用的這個const的語義是什么
            const引用表示,試圖通過此引用去(間接)改變其引用的對象的值時,編譯器會報錯!
            這并意味著,此引用所引用的對象也因此變成const類型了。我們?nèi)匀豢梢愿淖兤渲赶驅(qū)ο蟮闹担皇遣煌ㄟ^引用
            下面是一個簡單的例子:
             1 #include <iostream>
             2 using namespace std;
             3 
             4 int main()
             5 {
             6     int val = 1024;
             7     const int &ir = val;
             8     
             9     val++;
            10     //ir++;
            11 
            12     cout << val << " " << ir << endl;
            13 
            14     return 0;
            15 }


            其中第10行,如果我們通過ir來改變val的值,編譯時會出錯。但是我們?nèi)匀豢梢酝ㄟ^val直接改變其值(第9行)

            總結(jié):const引用只是表明,保證不會通過此引用間接的改變被引用的對象!

            個人總結(jié):這篇文章很好的解決了我在C++ Primer的P52遇到的問題,對于const的機制有了深一步的了解。
            posted on 2008-10-15 11:16 GLORY 閱讀(233) 評論(0)  編輯 收藏 引用 所屬分類: C/C++ Specification
            一本大道久久香蕉成人网| 久久久久久精品成人免费图片| 欧美成a人片免费看久久| 国产ww久久久久久久久久| 99久久免费国产特黄| 久久精品国产亚洲av高清漫画| 久久久久久久久66精品片| 久久夜色精品国产噜噜亚洲a| 久久一区二区免费播放| 久久人人超碰精品CAOPOREN| 亚洲国产成人久久综合区| 午夜精品久久久内射近拍高清| 国产精品一区二区久久精品无码| 伊人久久综在合线亚洲2019| 久久精品国产亚洲7777| 久久午夜免费视频| 久久久无码一区二区三区| 97精品久久天干天天天按摩| 嫩草影院久久国产精品| 久久久精品国产亚洲成人满18免费网站 | 无码日韩人妻精品久久蜜桃| 久久精品国产亚洲AV高清热| 色偷偷888欧美精品久久久| 久久国产精品波多野结衣AV| 日本WV一本一道久久香蕉| 久久精品亚洲中文字幕无码麻豆 | 国产精品一区二区久久精品涩爱| 蜜臀av性久久久久蜜臀aⅴ麻豆| 久久精品无码专区免费东京热 | 亚洲国产精品嫩草影院久久| 国产亚洲美女精品久久久2020| 久久久久成人精品无码中文字幕| 久久99热精品| 国产A三级久久精品| 亚洲综合久久综合激情久久| 久久这里的只有是精品23| 狠狠色丁香婷婷综合久久来| 99久久国产综合精品女同图片| 免费精品99久久国产综合精品| 日韩乱码人妻无码中文字幕久久 | 国产91色综合久久免费|