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

            c++中explict關鍵字的說明和使用

            先看下面這一個簡單的代碼吧

             1 #include <iostream>
             2 using namespace std;
             3 class my
             4 {
             5 private:
             6     int t;
             7 public:
             8     my(){};
             9     my(int i):t(i){};
            10     int get()
            11     {
            12         return t;
            13     }
            14     void print(my d)
            15     {
            16         cout<<d.get()<<endl;
            17     }
            18 };
            19 
            20 int main()
            21 {
            22     my t;
            23     int i=3;
            24     t.print(i);
            25     return 0;
            26 }

            main函數中t.print(i);的調用,my類里面print函數接受的數據類型的my,不是int,但這段程序仍然能夠正常運行,是因為my類里面存在一個只有一個形參的構造函數。

            當在一個需要my類型對象的地方(比如print函數,就需要一個my類型對象),但是如果卻沒有給一個my類型對象,給了一個其他類型的對象,比如int,那么這個時候就會看這個類有沒有定義一個只接受一個參數的構造函數,而且這個形參必須是int,然后構造出一個my類型臨時對象,再把這個臨時對象給需要my類對象的地方,完成一種隱式的轉換。
            注意:如果這個類有一個接受一個參數的構造函數,但是這個參數的類型比如是string,這個隱式轉換肯定就不會發生了,編譯時會提示錯誤。

            總之,隱式轉換會發生在,本來需要一個這種類對象的時候,卻給了一個其他的數據類型,而且類也恰好有一個只接受一個這種數據類型參數的構造函數,就會先調用這個構造函數生成一個臨時對象,接著將這臨時對象用于需要這種類對象的地方。

            但是很多時候,這種隱式轉換會帶來很大的麻煩,因此如果自己定義的類中,有一個只接受一個參數的構造函數,除非有一個好理由允許構造函數被用于隱式類型轉換,否則那么就要在這個構造函數前面加一個關鍵詞 explicit,表明不會發生隱式轉換。

            posted on 2012-09-19 18:15 古月 閱讀(651) 評論(0)  編輯 收藏 引用 所屬分類: C/C++

            <2012年9月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456

            導航

            統計

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            文章檔案

            C++/C

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            評論排行榜

            午夜精品久久久久9999高清| 亚洲AV成人无码久久精品老人 | 日产精品久久久一区二区| 色综合久久无码中文字幕| 99久久99久久精品国产| 亚洲伊人久久成综合人影院| 久久99精品国产99久久6男男| 久久99精品久久久久久9蜜桃| 婷婷五月深深久久精品| 久久久久18| 青青草国产精品久久| 久久精品亚洲精品国产色婷| 亚洲欧美精品一区久久中文字幕 | 久久久久国产亚洲AV麻豆| 欧美熟妇另类久久久久久不卡| 久久人人爽人爽人人爽av| 国内精品久久国产大陆| 亚洲中文字幕无码久久综合网| 久久这里有精品视频| 狠狠色伊人久久精品综合网| 久久国产免费观看精品3| 思思久久好好热精品国产| 精品久久久久久无码人妻蜜桃| 久久99精品久久只有精品| 国内精品人妻无码久久久影院导航| 久久国产V一级毛多内射| 91亚洲国产成人久久精品| 四虎国产精品免费久久5151| 国产午夜免费高清久久影院 | 久久精品无码专区免费| 99久久婷婷国产一区二区| 久久免费视频网站| 2020最新久久久视精品爱| 久久综合丝袜日本网| 久久综合久久综合久久| 一级做a爱片久久毛片| 国产精品一区二区久久精品无码 | 亚洲va久久久噜噜噜久久| 久久亚洲私人国产精品vA | 久久人人爽人人人人片av| 亚洲精品无码久久久影院相关影片|