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

            ivy-jie

            progress ...

            C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
              9 Posts :: 41 Stories :: 6 Comments :: 0 Trackbacks

            派生類的對象都含有基類對象作為其一部分,我們可以將指向派生類型的引用轉(zhuǎn)換為指向它的基類型的引用,像轉(zhuǎn)換指針一樣,我們可以用派生類的對象初始化或賦值基類對象,反之卻不行。class base{
            public:
            };

            class derived:public base{
            public:
            };

            int main(void) {
                derived obj_d;
                base obj_b=obj_d;//賦值運算符
                base obj_b2(obj_d);//用派生類對象初始化

                derived &ref_d=obj_d;
                base &ref_b=ref_d;
                base &ref_b2(ref_d);

                cout<<"end in main\n";
                return EXIT_SUCCESS;
            }
             
            程序編譯沒有錯誤,只是會提示ref_b,ref_b2沒有使用,如果反過來轉(zhuǎn)換基類對象或引用為派生類型的則會報錯。
            實際上,這里編譯器并沒有將派生類對象或引用“轉(zhuǎn)換”為基類型的,只是用派生類對象中的基類部分初始化或賦值基類對象,引用方面,將派生類基類部分的地址傳遞給基類型的引用。
            前面在虛函數(shù)實例時,看到將派生類對象傳遞給參數(shù)為基類型引用的函數(shù),這時傳遞的是地址,實參的派生類對象還是派生類對象。
            如果是參數(shù)為基類對象的函數(shù),情況有所不同,實參派生類對象的基類部分會被復(fù)制給一個函數(shù)體內(nèi)建立的臨時的基類對象。

            當我們用派生類對象初使化或賦值基類對象時,有兩種可能:
            1.基類中定義了相應(yīng)的構(gòu)造函數(shù)和重載了賦值運算符,這時將會按照相應(yīng)的函數(shù)進行
            class derived;
            class base{
            public:
                base(const derived&);
                base& operator=(derived &);
            };
             

            2.基類中并沒有定義相關(guān)的函數(shù),與情況1相比,這種情況更為常見。
              通常基類中會有考構(gòu),其參數(shù)為const 基類型引用考構(gòu)會幫我們完成派生類對象初始化或賦值基類型對象,其中發(fā)生指向派生類的引用轉(zhuǎn)換為基類型的引用。開頭的示例程序:

                base obj_b=obj_d;//賦值運算符
                base obj_b2(obj_d);//用派生類對象初始化,調(diào)用的構(gòu)造函數(shù)
            派生類中的基類部分好像被“切割”(slice down)下一樣,賦值給基類對象。

            派生類-基類 轉(zhuǎn)換后的成員訪問問題
              如果是公有派生,轉(zhuǎn)換后,可以訪問基類對象的相應(yīng)成員,如果是保護或私有派生則不可。
            class base{
            public:
                int pub;
            protected:
                int pro;
            };

            class derived:public base{
            public:
            };

            int main(void) {
                derived obj_d;
                base obj_b=obj_d;//賦值運算符

                cout<<obj_b.pub<<" "<<endl;
                cout<<"end in main\n";
                return EXIT_SUCCESS;
            }

             
            程序沒有任何問題,輸出結(jié)果為一隨機值,因為我們沒有定義任何構(gòu)造函數(shù)為數(shù)據(jù)成員初始化。
            如果將派生類型變?yōu)楸Wo或私有
            class derived:protected base{
            public:
            };
             
            編譯報錯  `base' is an inaccessible base of `derived'
            而且,私有派生時,其后續(xù)派生的類是不可轉(zhuǎn)換為基類型的,保護派生可以。

            基類-派生類 的轉(zhuǎn)換
            無論是用基類對象還是引用初始化派生類對象或引用都是不可以的,基類對象其所占的內(nèi)存空間中并沒有派生類所定義的只屬于它自己的那一部分。即使是有一個基類型的引用,其此時正好指向一個派生類對象,我們也不可將其轉(zhuǎn)換為派生類型的引用,因為編譯時編譯器檢查的是靜態(tài)類型。

            posted on 2009-06-28 11:06 ivy-jie 閱讀(791) 評論(0)  編輯 收藏 引用

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


            久久久久久午夜精品| 国产成人无码久久久精品一| 99久久中文字幕| 爱做久久久久久| 亚洲一级Av无码毛片久久精品| 久久天天躁狠狠躁夜夜不卡| 99久久99久久精品国产片果冻| 精品国产乱码久久久久久郑州公司 | 国产亚洲精品久久久久秋霞| 精品国产乱码久久久久久1区2区| 99久久精品国产一区二区三区| 久久久黄片| 久久国产精品一区二区| 亚洲美日韩Av中文字幕无码久久久妻妇 | 久久超碰97人人做人人爱| 久久精品成人一区二区三区| 亚洲精品无码成人片久久| 久久久精品国产Sm最大网站| 久久精品国产亚洲AV香蕉| 污污内射久久一区二区欧美日韩| 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 九九久久精品无码专区| 国产激情久久久久久熟女老人 | 思思久久好好热精品国产| 久久精品这里热有精品| 久久久久人妻一区精品色| 99精品国产免费久久久久久下载| 国产精品伦理久久久久久| 久久久久99精品成人片欧美| 少妇久久久久久被弄到高潮 | 久久亚洲精品成人AV| 污污内射久久一区二区欧美日韩 | 久久99久久成人免费播放| 精品国际久久久久999波多野| 中文字幕无码精品亚洲资源网久久 | 日日狠狠久久偷偷色综合0| 国产午夜精品久久久久九九| 久久九九全国免费| 亚洲伊人久久大香线蕉苏妲己| 国产精品九九九久久九九| 免费观看久久精彩视频|