• <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>
            隨筆-59  評論-36  文章-0  trackbacks-0
            問題1:
            class Base1
            {
            public:
                
            virtual void f()
                
            {
                    cout 
            << "Base1::f" << endl;
                }

                
            virtual void g()
                
            {
                    cout 
            << "Base1::g" << endl;
                }

            }
            ;
            class Base2 :public virtual Base1
            {
            public:

                
            virtual void f()
                
            {
                    cout 
            << "Base2::f" << endl;
                }

                
            virtual void g()
                
            {
                    cout 
            << "Base2::g" << endl;
                }

            }
            ;

            class Base3:public virtual Base1
            {
            public:

                
            virtual void f()
                
            {
                    cout 
            << "Base3::f" << endl;
                }

                
            virtual void g()
                
            {
                    cout 
            << "Base3::g" << endl;
                }

            }
            ;

            class Derive : public Base2, public Base3 {
            public:
            virtual void g() { cout << "Derive::g1" << endl; }
            }
            ;

            以上代碼是在論壇中遇見的,當(dāng)時我并沒有立刻反應(yīng)上來這是什么緣故,思索一陣后,才弄明白。
            原來,在Derive中沒有重寫f函數(shù),又因?yàn)楫?dāng)派生類沒有重寫基類的虛函數(shù)時,派生類對象對該虛函數(shù)的調(diào)用,將會調(diào)用其基類中的版本,而Derive又是多繼承,于是在Derive繼承時就不知道Base1中的虛函數(shù)表應(yīng)該記錄哪個版本的f函數(shù),是Base2,還是Base3。
            因?yàn)镈erive中已重定義g函數(shù),Base1的虛函數(shù)表記錄的是Derive::g。

            ==============================================================================

            問題2:
            代碼來源<effective C++>2nd

            class Lottery
            {
            public:
              
            virtual int draw();
            };

            class GraphicalObject 
            {
            public:
              
            virtual int draw();
            };

            class LotterySimulation: public Lottery,
                                     
            public GraphicalObject 
            {
              
            // 沒有聲明draw
            };

            LotterySimulation 
            *pls = new LotterySimulation;

            pls
            ->draw();   // 錯誤! ---- 二義

            因?yàn)長otterySimulation中存在兩個名為draw的函數(shù),于是調(diào)用存在二義性。同時,即便更改其中一個draw的訪問性也不能避免這種二義性,因?yàn)楦淖円粋€類成員的訪問權(quán)限不應(yīng)該改變程序的含義。
            對于如下代碼,仍然存在二義性
            class SpecialLotterySimulation: public LotterySimulation 
            {
            public:
              
            virtual int draw();
            };

            pls 
            = new SpecialLotterySimulation;

            pls
            ->draw();     // 錯誤!  還是有二義
            因?yàn)椋琾ls的靜態(tài)類型是LotterySimulation,而名字的查找是向上進(jìn)行的,所以即便SpecialLotterySimulation中定義了一個draw,對pls來說他是不會查看SpecialLotterySimilation中的名稱的。
            posted on 2009-10-28 12:51 zhaoyg 閱讀(1146) 評論(0)  編輯 收藏 引用 所屬分類: C/C++學(xué)習(xí)筆記
            久久WWW免费人成—看片| 久久综合久久综合九色| 久久热这里只有精品在线观看| 久久国产AVJUST麻豆| 蜜桃麻豆WWW久久囤产精品| 久久发布国产伦子伦精品 | 亚洲精品国产美女久久久| 亚洲人成精品久久久久| 亚洲国产天堂久久综合网站| 久久91精品国产91久| 欧美久久综合性欧美| 777午夜精品久久av蜜臀| 国产高潮国产高潮久久久91| 亚洲日韩中文无码久久| 久久激情五月丁香伊人| 国产一区二区三区久久精品| 一级A毛片免费观看久久精品| 久久99国产精品99久久| 亚洲精品无码专区久久久| 久久伊人影视| 久久精品国产精品亚洲下载| 1000部精品久久久久久久久| 无码人妻精品一区二区三区久久 | 老男人久久青草av高清| 国産精品久久久久久久| 2021久久国自产拍精品| 久久人人妻人人爽人人爽| 亚洲精品tv久久久久| 久久久久婷婷| 一级做a爰片久久毛片看看| 精品国产91久久久久久久a| 91精品日韩人妻无码久久不卡| 国产亚洲婷婷香蕉久久精品| 久久综合香蕉国产蜜臀AV| 久久精品国产乱子伦| 亚洲AV日韩精品久久久久| 久久久久亚洲AV成人片| 久久99国产精一区二区三区| 久久精品国产秦先生| 国产高清美女一级a毛片久久w| 大蕉久久伊人中文字幕|