• <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>

            孔雀開發小屋

            專注并致力于手機客戶端開發
            <2011年11月>
            303112345
            6789101112
            13141516171819
            20212223242526
            27282930123
            45678910

            統計

            • 隨筆 - 103
            • 文章 - 0
            • 評論 - 251
            • 引用 - 0

            常用鏈接

            留言簿(38)

            隨筆分類

            隨筆檔案

            關注的博客

            朋友的博客

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            C++的一個疑惑
            各位請看下面的代碼
             1 struct A {};
             2 
             3 struct B
             4 {
             5 public:
             6     B(){}
             7     B(A& a){}
             8 };
             9 
            10 struct B1 : public B
            11 {
            12 public:
            13     B1(const B& b) : B(b)
            14     {}
            15 };
            16 
            17 int main()
            18 {
            19     A a;
            20     B1 b1(a);
            21 
            22     return 0;
            23 }

            上面的代碼可以編譯通過(gcc和vs2005下均測試通過),但是如果我將第13行的const修飾符去掉,編譯就不能通過,報錯說沒有匹配的函數,請問各位高手這是為什么?望指教。

            posted on 2010-12-20 21:15 孔雀 閱讀(2605) 評論(12)  編輯 收藏 引用 所屬分類: C/C++

            評論

            # re: C++的一個疑惑 2010-12-20 22:04 keane

            非const的引用參數只能是相同類型,const的引用參數可以傳相關類型的參數進來
              回復  更多評論    

            # re: C++的一個疑惑 2010-12-20 22:22 路人

            加上const 才能接受"右值(right value)"引用
              回復  更多評論    

            # re: C++的一個疑惑 2010-12-20 22:37 Rollen Holt

            受教
              回復  更多評論    

            # re: C++的一個疑惑 2010-12-20 22:43 luckycat

            B(A& a){} 不但是一個構造函數,而且是一個自定義的類型轉換操作( A -> B),你的問題有出在這里,如果要去掉這種非有意的自定義類型轉換,使用 explicit B(A& a){}。

            一個 非const引用,只能引用與其類型完全相同的對象,或者是其派生類的對象 ,所以 B &refB = objectB ; B &refB = objectB1 都是合法的,但是 B &refB = objectA 就不是合法的
            ,因為 A 與 B的類型不相同,且不是B的派生類,所以編譯時會報錯,于是 " B1( B& b ); A a; B1 b1(a)" 就不能通過,簡化一下就相當于 " B &b = a".

            一個 const引用 滿足 非const引用 的特性的同時,還有很重要的一點,const 引用可以引用一個與其類型完全不相同的類型(因為編譯器會生成一個轉換后可引用的臨時對象),
            前提是被引用的類型可以轉換為引用的類型(編譯器自定義的類型提升,或者是用戶自定義的類型轉換,如上面的 B(A& a)。 ),
            舉個例子:
            const int &iValue = 3.14; 就是OK的,這里使用編譯器內部的類型轉換 double -> int.
            const B &b = a; 也是OK的,因為使用 B( A &a) 可以將 A -> B ,于是 const B &b = a; 的背后,編譯器所做的就是:

            const B tempB( a ); //調用 B( A &a)
            const B &b = tempB;


            BTW: 為什么在const引用情況下,編譯器會生成一個可被引用的臨時對象,原因很簡單,你是用一個 const引用 來操作這個臨時對象,所以,這個臨時對象的狀態是不會變的,
            也就是安全的(當然,如果你把const引用 const_cast 成一個非 const引用來操作這個編譯器生成的臨時對象,那么結果是未定義的).
              回復  更多評論    

            # re: C++的一個疑惑 2010-12-20 22:48 Rollen Holt

            如果樓主想看同類問題的話可以去我的博客:http://www.cnblogs.com/rollenholt/articles/1912141.html
            希望對你有幫助
              回復  更多評論    

            # re: C++的一個疑惑 2010-12-20 23:06 xyfor1234

            B(A& a){}是一個隱式的類型轉換函數,當執行B1 b1(a)時會自動調用這個函數將a轉換成B類型的臨時對象b。這種系統自動生成的臨時對象都是const的,而const對象是無法轉換成非const對象的,所以B1(const B& b) : B(b)這里一定要加const.effective C++里面對這個問題講得很清楚,自己找來看看吧。
              回復  更多評論    

            # re: C++的一個疑惑 2010-12-21 11:10 kongque

            謝謝大家。我明白了。
              回復  更多評論    

            # re: C++的一個疑惑 2010-12-21 11:12 kongque

            @luckycat
            非常感謝這么詳盡的回復,受教了。
              回復  更多評論    

            # re: C++的一個疑惑 2010-12-21 11:22 f

            關鍵在于,要進行類型轉換(將A轉為B)生成一個 B類 的臨時對像。
            C++中對臨時對像只能 const引用,而禁止直接引用(不允許直接修改臨時對像)。
              回復  更多評論    

            # re: C++的一個疑惑[未登錄] 2010-12-24 14:10 vincent

            俺也受教了:)
              回復  更多評論    

            # re: C++的一個疑惑 2011-01-26 09:27 loop

            臨時對象,右值引用。呵呵。。
              回復  更多評論    

            # re: C++的一個疑惑 2012-09-21 19:20 雨花石shine

            你那個是一個拷貝構造函數了吧,如果不用const好像會有一個自拷貝出現,到時候析構函數析構的時候會在同一個地方析構兩次,所有會報錯,用const的用處實際上很多的時候是防止自拷貝的出現。
              回復  更多評論    
            久久久久人妻一区精品果冻| 亚洲国产另类久久久精品| 久久久久亚洲AV片无码下载蜜桃| www久久久天天com| 久久经典免费视频| 国内精品久久久久久麻豆 | 品成人欧美大片久久国产欧美| 亚洲国产精品无码久久青草| 久久精品国产精品青草| 欧洲成人午夜精品无码区久久| 午夜精品久久久久9999高清| 久久久婷婷五月亚洲97号色| 久久综合久久综合九色| 麻豆精品久久久一区二区| 波多野结衣久久一区二区| 久久这里都是精品| 精品久久久久久国产| 噜噜噜色噜噜噜久久| 久久激情亚洲精品无码?V| 久久天天躁狠狠躁夜夜avapp| 久久国产精品无码网站| 久久精品国产亚洲一区二区| 亚洲色大成网站WWW久久九九| 亚洲国产精品无码久久久蜜芽 | 蜜臀久久99精品久久久久久| 久久久久九国产精品| 国产精品久久久久影视不卡| 久久青青草原国产精品免费| 精品久久久中文字幕人妻| 久久精品无码午夜福利理论片| 久久久久久久免费视频| 久久精品无码一区二区三区免费| 欧美久久综合性欧美| 国产成人久久激情91| 成人久久久观看免费毛片| 久久精品国产精品亚洲毛片| 99蜜桃臀久久久欧美精品网站 | 久久精品视频网| 精品一区二区久久| 久久免费小视频| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 |