• <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>
            Dict.CN 在線詞典, 英語學(xué)習(xí), 在線翻譯

            學(xué)??嘧髦?,書山勤為徑

            留下點回憶

            常用鏈接

            統(tǒng)計

            積分與排名

            Denoise

            English study

            Web技術(shù)

            數(shù)據(jù)壓縮

            一些連接

            最新評論

            dynamic_cast介紹

            dynamic_cast<type-id> (expression)

            這個表達(dá)式將 expression 轉(zhuǎn)換為一個 type-id 類型的對象。 Type-id 必須是一個指針、指向一個已經(jīng)定義類的類型或一個指向 VOID 的指針。 Expression 的類型必須是一個指針,如果 type-id 是一個指針;當(dāng) type-id 是一個引用的時候必須是一個左值。

            如果 type-id 是一個到 expression 類的直接或間接的模棱兩可的指針,結(jié)果是一個到 type-id 類型的子對象:

            class B { ... };

            class C : public B { ... };

            class D : public C { ... };

            ?

            void f(D* pd)

            {

            ?? C* pc = dynamic_cast<C*>(pd);?? // ok: C 是一個直接的基類

            ???????????????????????????????? // pc 指向 pd C 子對象

            ?

            ?? B* pb = dynamic_cast<B*>(pd);?? // ok: B 是一個間接的基類

            ??????????????????????????? ?????// pb 指向 pd B 子對象

            ?? ...

            }

            這個類型轉(zhuǎn)換叫做向上轉(zhuǎn)型,因為它將一個指針在其繼承層次向上轉(zhuǎn)型,即從一個繼承類到其基類。向上轉(zhuǎn)型是隱式轉(zhuǎn)換。

            如果 type-id 是一個 void* ,運行時檢查將決定表達(dá)式的實際類型。結(jié)果是一個到 expression 指向的完整對象。例如:

            class A { ... };

            ?

            class B { ... };

            ?

            void f()

            {

            ?? A* pa = new A;

            ?? B* pb = new B;

            ?? void* pv = dynamic_cast<void*>(pa);

            ?? // pv 指向一個 A 類型的對象

            ?? ...

            ?? pv = dynamic_cast<void*>(pb);

            ?? // pv 指向一個 B 類型的對象

            }

            如果 type-id 不是 void* ,運行時檢查指向 expression 的對象能否轉(zhuǎn)換為指向 type-id 類型的對象。

            如果 expression 類型是 type-id 的基類,運行時檢查是否 expression 實際是一個指向 type-id 類型的完整對象,如果是,結(jié)果返回指向 type-id 類型的完整對象,否則返回 NULL 。例如:

            class B { ... };

            class D : public B { ... };

            void f()

            {

            ?? B* pb = new D;???????????????????? // unclear but ok

            ?? B* pb2 = new B;

            ?? D* pd = dynamic_cast<D*>(pb);????? // ok: pb 實際指向 D

            ?? ...

            ?? D* pd2 = dynamic_cast<D*>(pb2);?? // pb2 實際指向 B 而不是 D

            ????????? ??????????????????????????// 轉(zhuǎn)換失敗, pd2 NULL

            ?? ...

            }

            向下類型轉(zhuǎn)換之所以這么說是因為其從類繼承層次的父類向子類轉(zhuǎn)換。

            在多重繼承的情況,可能導(dǎo)致二義性??匆幌孪旅娴念惱^承層次:

            H1.bmp


            指向類型D的指針轉(zhuǎn)換為BC都正常,但如果從D轉(zhuǎn)換到A將會怎么樣來?這個結(jié)果導(dǎo)致轉(zhuǎn)換的二義性錯誤;為了結(jié)果這個問題,你可以指向兩次明確的轉(zhuǎn)型,例如:

            void f()

            {

            ?? D* pd = new D;

            ?? A* pa = dynamic_cast<A*>(pd);??? ??// 錯誤:二義性

            ?? B* pb = dynamic_cast<B*>(pd);????? // 首先轉(zhuǎn)換到 B

            ?? A* pa2 = dynamic_cast<A*>(pb);?? // ok: 明確的

            }

            在使用虛基類的時候就導(dǎo)致更復(fù)雜的模糊;看下面的類層次圖:

            H2.bmp


            在這個繼承層次中,A是虛基類。假定一個類E的實例并且一個指向A子對象的指針,一次到Bdynamic_cast會由于不明確性導(dǎo)致失敗,你必須首先轉(zhuǎn)換到適當(dāng)?shù)膶哟?,然后再向上轉(zhuǎn)換到確定的層次,一直按照這種方式直到到達(dá)正確的B對象。

            看下面的類層次圖:

            H3.bmp


            假定一個類型E的對象和一個指向D子對象的指針,從D子對象導(dǎo)航到左上A子對象,必須執(zhí)行三個轉(zhuǎn)換。從DEdynamic_cast的轉(zhuǎn)換,然后一個從EB的轉(zhuǎn)換(可以是dynamic_cast或者隱式轉(zhuǎn)換),最終是從BA的轉(zhuǎn)換,例如:

            void f(D* pd)

            {

            ?? E* pe = dynamic_cast<E*>(pd);// 這里的 D 實際上是 E 類型的對象

            ?? B* pb = pe;????? // upcast, implicit conversion

            ?? A* pa = pb;????? // upcast, implicit conversion

            }

            dynamic_cast 操作能執(zhí)行交叉轉(zhuǎn)換,使用上面相同的類層次,從 B 子對象到 D 子對象轉(zhuǎn)換是可能的,只要完整的對象是 E 。

            由于交叉轉(zhuǎn)換,從 D 指針到左上角 A 子對象的指針是可行的;首先從 D B 的交叉轉(zhuǎn)換,然后隱式從 B A 的轉(zhuǎn)換。例如:

            void f(D* pd)

            {

            ?? B* pb = dynamic_cast<B*>(pd);????? // cross cast

            ?? A* pa = pb;?????????????? ???// upcast, implicit conversion

            }

            一個 NULL 指針值通過 dynamic_cast 轉(zhuǎn)換到一個 NULL 指針。

            當(dāng)使用 dynamic_cast < type-id > ( expression ) 時, 如果 expression 不能安全的轉(zhuǎn)換到 type-id ,運行時檢查導(dǎo)致轉(zhuǎn)型失敗,例如:

            class A { ... };

            ?

            class B { ... };

            ?

            void f()

            {

            ?? A* pa = new A;

            ?? B* pb = dynamic_cast<B*>(pa);????? // fails, not safe;

            ??????????????????????????????????? // B not derived from A

            ?? ...

            }

            轉(zhuǎn)換失敗的指針類型是 NULL 指針。失敗的引用類型轉(zhuǎn)換拋出 bad_cast_exception 異常;如果 expression 沒有指向或引用一個有效的對象將拋出 __non_rtti_object 異常。

            posted on 2006-03-28 22:25 笨笨 閱讀(6189) 評論(2)  編輯 收藏 引用

            評論

            # re: dynamic_cast介紹 2006-03-30 14:46 小石

            是否可以這樣理解
            dynamic_cast主要設(shè)計目的是類對象指針和類對象左值的向下裝換?
            static_cast則主要用于簡單數(shù)據(jù)類型之間的轉(zhuǎn)換?  回復(fù)  更多評論   

            # re: dynamic_cast介紹 2006-03-30 20:10 笨笨

            dynamic_cast保證安全的轉(zhuǎn)換,因為如果不成功返回的是NULL,而static_cast一般用于簡單類型,對于復(fù)雜的向下轉(zhuǎn)換是不確定的  回復(fù)  更多評論   

            久久精品99久久香蕉国产色戒 | 狠狠综合久久AV一区二区三区| 久久午夜无码鲁丝片午夜精品| 伊人热热久久原色播放www| 亚洲精品乱码久久久久久| 国产激情久久久久影院小草 | 国产精品久久精品| 久久久久99这里有精品10 | 成人妇女免费播放久久久| 久久这里只有精品视频99| 久久天天躁狠狠躁夜夜躁2014| 亚洲国产成人久久综合碰| 婷婷综合久久中文字幕蜜桃三电影 | 欧美久久久久久| 9久久9久久精品| 久久久久久久免费视频| 国产精品成人99久久久久91gav| 香蕉久久影院| 狠狠色狠狠色综合久久| 人妻无码久久精品| 国产叼嘿久久精品久久| 久久国产精品99精品国产| 欧美亚洲国产精品久久久久| 久久嫩草影院免费看夜色| 26uuu久久五月天| 亚洲七七久久精品中文国产| 久久综合中文字幕| 国产午夜精品理论片久久| 精品国产乱码久久久久久浪潮| 97久久久精品综合88久久| 午夜精品久久久久久| 久久精品一区二区影院| 久久精品夜色噜噜亚洲A∨| 久久精品国产影库免费看| 久久久人妻精品无码一区| 国产成人久久精品麻豆一区| 久久精品国产网红主播| 国内精品久久久久久99| 久久久久亚洲AV无码网站| 午夜天堂精品久久久久| 亚洲av成人无码久久精品 |