• <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 閱讀(283) 評論(0)  編輯 收藏 引用 所屬分類: VC / C++
            欧美亚洲另类久久综合| 欧美精品九九99久久在观看| 国产精品久久久久久久app| 亚洲欧美久久久久9999| 亚洲AV日韩AV天堂久久| 新狼窝色AV性久久久久久| 日本免费一区二区久久人人澡 | 99久久亚洲综合精品成人| 四虎影视久久久免费观看| 久久91亚洲人成电影网站| 精品久久综合1区2区3区激情| 久久久亚洲欧洲日产国码二区| 久久久久久毛片免费看| 99国产精品久久| 精品国产一区二区三区久久久狼| 无码任你躁久久久久久老妇| 日本三级久久网| 久久香蕉国产线看观看乱码| 婷婷伊人久久大香线蕉AV | 久久久久亚洲av无码专区导航 | 亚洲狠狠婷婷综合久久久久| 久久久久亚洲AV成人网人人网站| 久久久久国产精品| 日韩精品国产自在久久现线拍| 99精品久久久久中文字幕| 久久精品国产亚洲AV嫖农村妇女| 中文字幕乱码人妻无码久久| 狼狼综合久久久久综合网| 久久99国产精品99久久| 久久嫩草影院免费看夜色| 久久久噜噜噜久久中文字幕色伊伊| 久久久久久久免费视频| 久久香蕉国产线看观看乱码| 欧美久久久久久精选9999| 久久国产欧美日韩精品| 国产精品久久自在自线观看| 久久AⅤ人妻少妇嫩草影院| 久久精品国产亚洲av日韩| 一本久久精品一区二区| 97精品久久天干天天天按摩| 四虎亚洲国产成人久久精品|