• <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風(fēng)格轉(zhuǎn)型幾乎允許你把任何類型轉(zhuǎn)換成任何其他類型(當(dāng)然有些限制)

            由于他的功能太強(qiáng)大,對(duì)于程序員閱讀這樣的程序會(huì)帶來很大的識(shí)別障礙

            幾乎所有的工作都用(type)expression的方式進(jìn)行轉(zhuǎn)換

            為此C++提供了4種新的轉(zhuǎn)型操作符號(hào)(cast operation)
            static_cast,const_cast,dynamic_cast和reinterpret_cast

            1.static_cast
               static_cast基本擁有c風(fēng)格轉(zhuǎn)型差不多的功能,和相同的限制。比如int向double的轉(zhuǎn)換
               int testNum;
               static_cast<double>testNum;
               同樣你也不能將int或者struct轉(zhuǎn)換成pointer,這個(gè)轉(zhuǎn)換在c里面也是不允許的

               值得注意的是static_cast不支持const向non-const的互相轉(zhuǎn)換,就是說不能排除表達(dá)式的常量性
               const_cast負(fù)責(zé)這一功能
            2.const_cast
               const_cast專注于這一功能,應(yīng)用面很狹窄,大使增加了可讀性。
               class A{...}
               class AB:public A{...}
               void Update(AB* xy);

               AB ab;
               const AB& cab = ab;
               Update(&cab);//這樣是錯(cuò)誤的
               Update(const_cast<CAB*>(&cab));//正確,去掉了常量性

               但是 const_cast不支持帶有繼承關(guān)系的轉(zhuǎn)換
               A* pa = new AB;
               Update(const_cast<AB*>pa);//這樣是錯(cuò)誤的
               現(xiàn)在我只需要記住。const_cast最重要的作用就是去除常量性
            3.dynamic_cast
               用來執(zhí)行繼承體系中安全的向下轉(zhuǎn)型或者跨系轉(zhuǎn)換,上面的操作用dynamic_cast是可以支持的
               A* pa = new AB;
               Update(dynamic_cast<AB*>pa);
               注意的是關(guān)于此操作符的返回值
               如果表達(dá)式是pointer ,轉(zhuǎn)換失敗的話會(huì)得到一個(gè)NULL
               如果............是ref       ,........................會(huì)拋出一個(gè)異常
               dynamic_cast只能做這一類型的轉(zhuǎn)換,請(qǐng)不要嘗試去用dynamic_cast改變表達(dá)式的常量性,也無法在缺乏虛函數(shù)的型別上使用(比如int to double,這樣的轉(zhuǎn)換得使用static_cast)
            4.reinterpret_cast
               這個(gè)我了看的不是很透,資料上說與編譯環(huán)境相關(guān),不具備移植性。
               他最常用途是轉(zhuǎn)換(函數(shù)指針)的型別
               有一個(gè)保存函數(shù)指針的數(shù)組,里面指針指向函數(shù)的return 都是void
               但是你現(xiàn)在有個(gè)函數(shù)return為int,這個(gè)時(shí)候如果你想把這個(gè)函數(shù)放進(jìn)funcPtrArray
               如果沒有轉(zhuǎn)型是可能實(shí)現(xiàn)的
            typedefine void  (*FuncPtr())
               int func();
               funcPtrArray[0] = &func;//錯(cuò)誤,型別不對(duì)
                 funcPtrArray[0]  = reinterpret_cast(FuncPtr)(&func);//正確   
            久久久久久精品免费看SSS| 久久成人精品| 国产一级做a爰片久久毛片| 久久亚洲欧美日本精品| 久久精品无码一区二区日韩AV| 亚洲色欲久久久久综合网| 精品久久亚洲中文无码| 亚洲综合婷婷久久| 伊人久久综合无码成人网| 久久永久免费人妻精品下载| 久久久久亚洲AV无码麻豆| 国产成人精品久久一区二区三区av| 青青草国产97免久久费观看| 国产综合久久久久久鬼色| 久久国产精品视频| 久久精品国产亚洲AV无码麻豆| 久久国产成人| 嫩草影院久久99| 欧美噜噜久久久XXX| 亚洲国产成人久久精品99| 大美女久久久久久j久久| 久久久久久久久无码精品亚洲日韩| 四虎影视久久久免费| 久久免费线看线看| 国产精品99久久精品| 99蜜桃臀久久久欧美精品网站| 人妻无码久久精品| 久久综合五月丁香久久激情| 18岁日韩内射颜射午夜久久成人| 无码AV中文字幕久久专区| 国产69精品久久久久观看软件| 久久中文字幕无码专区| 久久精品国产72国产精福利| 99久久综合狠狠综合久久| 日韩亚洲欧美久久久www综合网| 韩国免费A级毛片久久| 午夜精品久久久久久99热| 亚洲精品无码专区久久久| 成人综合久久精品色婷婷| 日本五月天婷久久网站| 色妞色综合久久夜夜|