• <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++
            国产婷婷成人久久Av免费高清| 精品久久久久久国产潘金莲| 久久人人爽人人爽人人片av高请 | 亚洲成色999久久网站| 看全色黄大色大片免费久久久| 久久久亚洲裙底偷窥综合| 精品国产婷婷久久久| 久久中文娱乐网| 久久综合久久综合久久综合| 色综合久久久久综合体桃花网| 欧美精品一区二区久久| 亚洲&#228;v永久无码精品天堂久久| 99久久精品免费看国产一区二区三区| 久久国产视屏| 久久久久国产精品麻豆AR影院| 国产精品亚洲综合专区片高清久久久| 精品久久久久久无码专区不卡| 狠狠色狠狠色综合久久| 久久精品无码专区免费东京热 | 夜夜亚洲天天久久| 久久久久人妻一区精品果冻| 亚洲国产精品嫩草影院久久| 一本色道久久99一综合| 久久久久久一区国产精品| 亚洲欧美日韩久久精品 | 亚洲七七久久精品中文国产| 狠狠色丁香久久婷婷综合图片| 精品国产乱码久久久久久郑州公司| 久久无码av三级| 久久精品国产清自在天天线 | 久久成人国产精品二三区| 香港aa三级久久三级老师2021国产三级精品三级在 | 免费观看久久精彩视频| 久久综合九色综合网站| 色天使久久综合网天天| 久久九九久精品国产| 久久r热这里有精品视频| 丁香五月网久久综合| 国产精品美女久久久久| 国产精品女同久久久久电影院| 欧美黑人又粗又大久久久|