• <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++
            国产成人无码精品久久久免费| 欧美va久久久噜噜噜久久| 久久精品免费大片国产大片| 久久久91人妻无码精品蜜桃HD| AA级片免费看视频久久| 亚洲精品乱码久久久久久不卡| 亚洲午夜久久久久久久久电影网| 久久久久久九九99精品| 国产激情久久久久影院| 亚洲AV无码1区2区久久| 国产精品99久久精品爆乳| 三级三级久久三级久久| 久久91精品国产91久久小草| 国产精品久久久久久久人人看| 国产成人精品久久免费动漫| 午夜精品久久久久久影视777| 久久综合狠狠综合久久| 亚洲国产天堂久久久久久| 国产精品美女久久久m| 亚洲精品WWW久久久久久| 久久免费高清视频| 精品免费久久久久久久| 亚洲精品tv久久久久| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 亚洲精品无码久久久久去q| 色综合合久久天天综合绕视看| 一本久久知道综合久久| 手机看片久久高清国产日韩| 99久久精品国产综合一区| 久久精品国产亚洲AV大全| 久久久久久久波多野结衣高潮| 欧美伊人久久大香线蕉综合69| 91精品国产91久久| 日本久久久久久中文字幕| 久久精品国产99久久久| 色偷偷偷久久伊人大杳蕉| 久久精品青青草原伊人| 久久99热这里只频精品6| 色婷婷久久久SWAG精品| 日本久久中文字幕| 99久久国产亚洲综合精品|