• <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++學習過程中的點點滴滴

            C++編程過程中常見問題及錯誤

            常用鏈接

            統計

            聯想5G免費網絡硬盤

            最新評論

            C++類型轉換符的使用

            C++的四個類型轉換運算符已經有很久了,但一直沒有弄清楚它們的用法,今天看到一本書上的解釋,才大致地的了解了其具體的用法.

            具體歸納如下:

            reinterpret_cast

            該函數將一個類型的指針轉換為另一個類型的指針.
            這種轉換不用修改指針變量值存放格式(不改變指針變量值),只需在編譯時重新解釋指針的類型就可做到.
            reinterpret_cast 可以將指針值轉換為一個整型數,但不能用于非指針類型的轉換.
            例:
            //基本類型指針的類型轉換
            double d=9.2;
            double* pd = &d;
            int *pi = reinterpret_cast<int*>(pd);  //相當于int *pi = (int*)pd;

            //不相關的類的指針的類型轉換
            class A{};
            class B{};
            A* pa = new A;
            B* pb = reinterpret_cast<B*>(pa);   //相當于B* pb = (B*)pa;

            //指針轉換為整數
            long l = reinterpret_cast<long>(pi);   //相當于long l = (long)pi;


            const_cast

            該函數用于去除指針變量的常量屬性,將它轉換為一個對應指針類型的普通變量。反過來,也可以將一個非常量的指針變量轉換為一個常指針變量。
            這種轉換是在編譯期間做出的類型更改。
            例:
            const int* pci = 0;
            int* pk = const_cast<int*>(pci);  //相當于int* pk = (int*)pci;

            const A* pca = new A;
            A* pa = const_cast<A*>(pca);     //相當于A* pa = (A*)pca;

            出于安全性考慮,const_cast無法將非指針的常量轉換為普通變量。


            static_cast

            該函數主要用于基本類型之間和具有繼承關系的類型之間的轉換。
            這種轉換一般會更改變量的內部表示方式,因此,static_cast應用于指針類型轉換沒有太大意義。
            例:
            //基本類型轉換
            int i=0;
            double d = static_cast<double>(i);  //相當于 double d = (double)i;

            //轉換繼承類的對象為基類對象
            class Base{};
            class Derived : public Base{};
            Derived d;
            Base b = static_cast<Base>(d);     //相當于 Base b = (Base)d;


            dynamic_cast

            它與static_cast相對,是動態轉換。
            這種轉換是在運行時進行轉換分析的,并非在編譯時進行,明顯區別于上面三個類型轉換操作。
            該函數只能在繼承類對象的指針之間或引用之間進行類型轉換。進行轉換時,會根據當前運行時類型信息,判斷類型對象之間的轉換是否合法。dynamic_cast的指針轉換失敗,可通過是否為null檢測,引用轉換失敗則拋出一個bad_cast異常。
            例:
            class Base{};
            class Derived : public Base{};

            //派生類指針轉換為基類指針
            Derived *pd = new Derived;
            Base *pb = dynamic_cast<Base*>(pd);

            if (!pb)
             cout << "類型轉換失敗" << endl;

            //沒有繼承關系,但被轉換類有虛函數
            class A(virtual ~A();)   //有虛函數
            class B{}:
            A* pa = new A;
            B* pb  = dynamic_cast<B*>(pa);

            如果對無繼承關系或者沒有虛函數的對象指針進行轉換、基本類型指針轉換以及基類指針轉換為派生類指針,都不能通過編譯。

            posted on 2008-09-27 16:59 何靖 閱讀(2456) 評論(3)  編輯 收藏 引用

            評論

            # re: C++類型轉換符的使用[未登錄] 2008-09-28 10:10 raof01

            reinterpret_cast:重新解析位模式bit pattern。
            如:
            TYPE * t = new TYPE();
            unsigned long ul = reinterpret_cast<unsigned long>(t);
            delete t;  回復  更多評論   

            # re: C++類型轉換符的使用[未登錄] 2008-09-30 20:55 Michael

            請問你看的是什么書?  回復  更多評論   

            # re: C++類型轉換符的使用[未登錄] 2008-10-17 11:10 raof01

            BS的TC++PL  回復  更多評論   

            亚洲色欲久久久综合网| 无码人妻久久一区二区三区蜜桃| 亚洲香蕉网久久综合影视| 18岁日韩内射颜射午夜久久成人| 日本强好片久久久久久AAA| 国产精品天天影视久久综合网| 久久精品国产福利国产琪琪| 国产aⅴ激情无码久久| 国内精品久久久久国产盗摄| 午夜精品久久久久久99热| 日韩十八禁一区二区久久| 精品久久一区二区| 中文字幕久久久久人妻| 久久综合成人网| 久久综合综合久久狠狠狠97色88| 欧美日韩精品久久久久| 国内精品久久久久久不卡影院| 久久久国产精品亚洲一区| 久久精品国产亚洲av麻豆蜜芽| 久久久精品国产亚洲成人满18免费网站 | 久久午夜免费视频| 一本伊大人香蕉久久网手机| 久久久久亚洲AV无码专区体验| 欧美性猛交xxxx免费看久久久| 品成人欧美大片久久国产欧美...| 久久丫精品国产亚洲av不卡 | 97久久超碰国产精品旧版| 中文字幕精品无码久久久久久3D日动漫| 精品久久久久久无码专区| 亚洲国产精品无码久久一区二区| 国产精品久久久久a影院| 久久这里都是精品| 久久久久久精品成人免费图片 | 精品久久久久久久久久中文字幕| 9191精品国产免费久久| 色综合久久最新中文字幕| 国产成人综合久久久久久| 久久久久久A亚洲欧洲AV冫| 久久天天躁狠狠躁夜夜2020| 色偷偷91久久综合噜噜噜噜| 日本五月天婷久久网站|