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

            大龍的博客

            常用鏈接

            統(tǒng)計(jì)

            最新評(píng)論

            VC下用dynamic_cast的問題

            #include "iostream.h"
            class base
            {
            int i;
            public:
            base(int I = 0):i(I) {}
            virtual int value() const {return i;}
            };
            class derived:public base
            {
            public:
            derived(int I = 0):base(I) {}
            int value() const {return base::value()*2;}
            virtual int shift(int x) const {return base::value()<< x;}
            };
            void main()
            {
            base* B[] = {new base(7),new derived(8)};
            cout << "B[0]->value:"<<B[0]->value()<<endl;
            cout << "B[1]->value:"<<B[1]->value()<<endl;
            derived* cp = dynamic_cast<derived*>(B[1]);
            if(cp)
            {
            cp->shift(2);
            }
            //cout << "B[1]->value:"<<((derived*)B[1])->shift(2)<<endl;
            }

            原意是想使用dynamic_cast,看B[1]是否為derived*,然后調(diào)用derived才有的shift(),但程序編譯無錯(cuò),運(yùn)行時(shí)發(fā)生錯(cuò)誤,請(qǐng)問具體是什么原因.可否詳細(xì)講解一下dynamic_cast的用法.謝謝


            回復(fù)人: expert(技術(shù)專家)?? 信譽(yù):100
            測(cè)一下,由于沒有return值,線程的退出代碼即傳遞給ExitThread或者TerminateThread值未知,所以編譯器把exitcode當(dāng)作有返回的main來取,就是類似int main()有一個(gè)堆棧來保護(hù)返回值那樣, 把那個(gè)返回值取出來。所以exitcode總有不同。比如你僅僅是HANDLE hThread = ::GetCurrentThread();這時(shí)候的exitcode就是hThread的值。這應(yīng)該是編譯器行為。


            回復(fù)人: expert(技術(shù)專家)?? 信譽(yù):100
            暈。。。。'dynamic_cast' 當(dāng)然要加/GR
            樓主不會(huì)是這個(gè)錯(cuò)誤吧。。。。狂暈。。。
            自做多情了半天,還以為是exitcode有什么關(guān)系。

            以上僅僅是臆測(cè)~

            ?

            點(diǎn)評(píng):

            當(dāng)靜態(tài)型別與動(dòng)態(tài)型別不一治時(shí),由于虛擬函數(shù)時(shí)動(dòng)態(tài)鑒定的,所以,當(dāng)靜態(tài)是基類,而動(dòng)態(tài)是派生類時(shí),他會(huì)自動(dòng)執(zhí)行派生類的函數(shù).但是,對(duì)于,在派生類中新增加的函數(shù),不會(huì)自動(dòng)轉(zhuǎn)換,這個(gè)時(shí)候就會(huì)用到static_cast 或者是 dynamic_cast 轉(zhuǎn)換了,

            感覺是這樣,呵呵
            dynamic_cast是向下的轉(zhuǎn)化,就是A指針可以是否轉(zhuǎn)化為B類指針;
            它有什么用呢?
            當(dāng)我們必須使用派生類的特性,而該特性又沒有出現(xiàn)在基類中時(shí),我們常常要用到:

            posted on 2006-12-03 16:54 大龍 閱讀(595) 評(píng)論(1)  編輯 收藏 引用

            評(píng)論

            # re: VC下用dynamic_cast的問題 2011-04-29 17:02 hello


            try
            {
            derived* cp = dynamic_cast<derived*>(B[1]);
            }catch(bad_cast& bc)
            {
            }  回復(fù)  更多評(píng)論   


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            2019久久久高清456| 伊人久久综合精品无码AV专区| 久久综合九色综合网站| 亚洲国产另类久久久精品 | 亚洲国产精品人久久| 久久影视综合亚洲| 欧美熟妇另类久久久久久不卡| 久久综合狠狠色综合伊人| 久久av免费天堂小草播放| 污污内射久久一区二区欧美日韩 | 久久激情亚洲精品无码?V| 精品久久久久久国产潘金莲| 99精品久久久久久久婷婷 | 麻豆久久久9性大片| 欧美色综合久久久久久| 久久这里都是精品| 亚洲中文字幕无码一久久区| 亚洲国产精品无码久久| 久久夜色精品国产亚洲| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 欧美噜噜久久久XXX| 久久国产精品久久国产精品| 久久人人爽人人爽人人片AV麻豆| 久久久久人妻精品一区三寸蜜桃| 久久人人爽人人爽人人片AV不| 国产欧美久久久精品| 伊人久久五月天| 久久久久成人精品无码| 国产精品久久久久久久久| 久久精品国产免费观看| 欧美久久久久久| 久久天天躁狠狠躁夜夜2020一| 99久久精品国产毛片| 91精品国产91热久久久久福利| 国内精品久久人妻互换| 久久亚洲欧美国产精品 | 久久婷婷国产综合精品| 久久精品国产色蜜蜜麻豆| 婷婷综合久久中文字幕蜜桃三电影| 久久99热这里只有精品66| 人妻中文久久久久|