• <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++
            国产成人综合久久综合| 深夜久久AAAAA级毛片免费看| 亚洲伊人久久精品影院| 亚洲精品无码久久久久去q| 国产精品久久久久9999高清| 久久人人爽人人爽人人片AV东京热 | 久久久人妻精品无码一区| 久久久一本精品99久久精品88| 九九精品99久久久香蕉| 亚洲另类欧美综合久久图片区| 香蕉久久夜色精品升级完成| 久久久亚洲精品蜜桃臀| 久久久久久狠狠丁香| 久久99久久99精品免视看动漫| 99久久免费只有精品国产| 久久精品国产亚洲AV无码麻豆| 久久夜色精品国产www| 青青青青久久精品国产| 久久av无码专区亚洲av桃花岛| 青青热久久国产久精品 | 国产亚洲精品久久久久秋霞| 精品99久久aaa一级毛片| 狠狠色丁香久久婷婷综合五月| 一本色道久久综合| 久久精品综合网| 伊人久久大香线蕉AV一区二区| 久久精品视频91| 久久综合精品国产一区二区三区| 99久久精品这里只有精品| 久久99国产精品久久99| 久久精品人人做人人妻人人玩| 亚洲欧美日韩中文久久| 欧美一区二区三区久久综| 97久久国产露脸精品国产| 性欧美丰满熟妇XXXX性久久久 | 亚洲日韩欧美一区久久久久我| 亚洲国产成人久久综合碰碰动漫3d| 久久99精品国产99久久| 91久久国产视频| 一本色道久久88综合日韩精品 | 成人国内精品久久久久影院|