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

            積木

            No sub title

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              140 Posts :: 1 Stories :: 11 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(1)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            原文轉載自:http://www.cnblogs.com/cutepig/archive/2009/01/14/1375917.html

            按照默認規定,只有一個參數的構造函數也定義了一個隱式轉換,將該構造函數對應數據類型的數據轉換為該類對象,如下面所示:
            class String {
            String ( const char* p ); // 用C風格的字符串p作為初始化值
            //…
            }
            String s1 = “hello”; //OK 隱式轉換,等價于String s1 = String(“hello”);
             
            但是有的時候可能會不需要這種隱式轉換,如下:
            class String {
                   String ( int n ); //本意是預先分配n個字節給字符串
            String ( const char* p ); // 用C風格的字符串p作為初始化值
            //…
            }
             
            下面兩種寫法比較正常:
            String s2 ( 10 );   //OK 分配10個字節的空字符串
            String s3 = String ( 10 ); //OK 分配10個字節的空字符串
             
            下面兩種寫法就比較疑惑了:
            String s4 = 10; //編譯通過,也是分配10個字節的空字符串
            String s5 = ‘a’; //編譯通過,分配int(‘a’)個字節的空字符串
             
            s4 和s5 分別把一個int型和char型,隱式轉換成了分配若干字節的空字符串,容易令人誤解。
            為了避免這種錯誤的發生,我們可以聲明顯示的轉換,使用explicit 關鍵字:
            class String {
                   explicit String ( int n ); //本意是預先分配n個字節給字符串
            String ( const char* p ); // 用C風格的字符串p作為初始化值
            //…
            }
            加上explicit就抑制了String ( int n )的隱式轉換,
             
            下面兩種寫法仍然正確:
            String s2 ( 10 );   //OK 分配10個字節的空字符串
            String s3 = String ( 10 ); //OK 分配10個字節的空字符串
             
            下面兩種寫法就不允許了:
            String s4 = 10; //編譯不通過,不允許隱式的轉換
            String s5 = ‘a’; //編譯不通過,不允許隱式的轉換
             
            因此,某些時候,explicit 可以有效得防止構造函數的隱式轉換帶來的錯誤或者誤解

            ----------------------------------------------------------
            explicit   只對構造函數起作用,用來抑制隱式轉換。如:  
              class   A   {  
                      A(int   a);  
              };  
              int   Function(A   a);  
               
              當調用   Function(2)   的時候,2   會隱式轉換為   A   類型。這種情況常常不是程序員想要的結果,所以,要避免之,就可以這樣寫:  
               
              class   A   {  
                      explicit   A(int   a);  
              };  
              int   Function(A   a);  
               
              這樣,當調用   Function(2)   的時候,編譯器會給出錯誤信息(除非   Function   有個以   int   為參數的重載形式),這就避免了在程序員毫不知情的情況下出現錯誤。

            總結:explicit   只對構造函數起作用,用來抑制隱式轉換。

            參考:
            http://blog.csdn.net/smilelance/archive/2007/03/14/1528737.aspx
            http://topic.csdn.net/t/20040509/15/3046021.html
            posted on 2012-11-13 16:49 Jacc.Kim 閱讀(292) 評論(0)  編輯 收藏 引用 所屬分類: VC / C++
            热RE99久久精品国产66热| 97视频久久久| 国产精品欧美亚洲韩国日本久久| 久久99精品国产麻豆宅宅 | 亚洲精品乱码久久久久久久久久久久 | 久久久久亚洲AV成人片| 国产精品久久久福利| 欧美性猛交xxxx免费看久久久| 精品久久久无码21p发布| 亚洲国产精品人久久| 国内精品久久久久影院薰衣草| 久久久综合九色合综国产| 热久久最新网站获取| 99久久精品国产一区二区| 99久久无色码中文字幕人妻| 久久国产成人午夜AV影院| 久久久久人妻一区二区三区vr| 国内精品久久久久久中文字幕| 无遮挡粉嫩小泬久久久久久久 | 国产国产成人久久精品| 久久人妻少妇嫩草AV无码专区| 青青青青久久精品国产h久久精品五福影院1421 | 久久久久高潮毛片免费全部播放| 狠狠色伊人久久精品综合网| 国内精品久久人妻互换| 欧美日韩精品久久免费| 欧美日韩精品久久久久| 久久性生大片免费观看性| 久久噜噜电影你懂的| 青青青国产成人久久111网站| 色综合久久无码中文字幕| 欧美牲交A欧牲交aⅴ久久| 99久久精品国产一区二区 | 三级片免费观看久久| 四虎亚洲国产成人久久精品| 久久久WWW免费人成精品| 狠狠精品久久久无码中文字幕 | 国产AⅤ精品一区二区三区久久| 国产精品久久久久久久| 91精品国产综合久久四虎久久无码一级| 久久婷婷五月综合97色|