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

            孔雀開發小屋

            專注并致力于手機客戶端開發
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            統計

            • 隨筆 - 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 孔雀 閱讀(2604) 評論(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影院| 国产国产成人精品久久| 久久夜色精品国产亚洲| 青春久久| 日本道色综合久久影院| 青青草原精品99久久精品66| 久久r热这里有精品视频| 亚洲人成无码网站久久99热国产| 伊人久久大香线蕉av不变影院| 久久99国产精品久久99| 久久WWW免费人成一看片| 国产精品久久成人影院| 欧美日韩精品久久久久| 国产女人aaa级久久久级| 久久99这里只有精品国产| 久久精品国产亚洲麻豆| 99精品国产综合久久久久五月天| 国产成人综合久久久久久| 久久久久久久久久久久中文字幕| 久久久久99精品成人片三人毛片 | 久久91综合国产91久久精品| 国产免费久久久久久无码| 久久国产精品77777| 久久亚洲精品无码aⅴ大香 | 国产激情久久久久影院| 久久天天躁狠狠躁夜夜avapp| 久久国产成人午夜AV影院| 久久婷婷国产麻豆91天堂| 日韩人妻无码精品久久免费一 | 人人狠狠综合久久亚洲婷婷| 久久久久99精品成人片欧美| 婷婷五月深深久久精品| 久久综合亚洲色HEZYO国产| 精品久久久久久99人妻| 久久久精品日本一区二区三区| 精品久久久久久久久久中文字幕| 亚洲综合精品香蕉久久网97| 18岁日韩内射颜射午夜久久成人 | 少妇精品久久久一区二区三区|