• <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的用處實際上很多的時候是防止自拷貝的出現。
              回復  更多評論    
            国内精品伊人久久久久影院对白| 香港aa三级久久三级| 国产99久久久国产精品~~牛| 久久91精品国产91久久小草| 久久精品国产亚洲av日韩| 伊人丁香狠狠色综合久久| 色欲综合久久躁天天躁蜜桃| 国产亚洲婷婷香蕉久久精品| 色欲久久久天天天综合网精品 | 久久成人国产精品免费软件| 久久久久人妻一区精品色| 日日躁夜夜躁狠狠久久AV| 久久国产香蕉一区精品| 97精品依人久久久大香线蕉97| 国内精品久久久人妻中文字幕| 国内精品伊人久久久久网站| 久久亚洲中文字幕精品一区| 精品久久久久久亚洲精品| 激情伊人五月天久久综合| 色噜噜狠狠先锋影音久久| 久久综合九色综合网站| 国产精品久久久天天影视香蕉| 国产精品热久久无码av| 亚洲午夜无码AV毛片久久| 91秦先生久久久久久久| 无码人妻少妇久久中文字幕 | 久久久久亚洲AV无码麻豆| 久久综合给久久狠狠97色| 色综合久久久久| 久久综合视频网| 久久久这里有精品中文字幕| 国内精品久久久久影院亚洲| 91精品国产高清久久久久久io | 99久久成人18免费网站| 无夜精品久久久久久| 99久久婷婷国产综合亚洲| 亚洲精品国产自在久久| 久久久久久久尹人综合网亚洲| 亚洲精品国产综合久久一线| 国产高潮国产高潮久久久| 天堂无码久久综合东京热|