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

            Welcome to ErranLi's Blog!

              C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              106 Posts :: 1 Stories :: 97 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(12)

            搜索

            •  

            積分與排名

            • 積分 - 175087
            • 排名 - 151

            最新評論

            閱讀排行榜

                
            如果在派生類中要重載派生類的operator = ,那么在基類中一般不要重載operator = ,因為這樣會帶來很多麻煩.

            定義了兩個類:
             class CBase
            {  
            public:
               CBase()
               {
                    cout<<"CBase constructing ..."<<endl;
                }
               virtual ~CBase()
               {
                    cout<<"CBase destructing ..."<<endl;
                }
            public:
               CBase & operator=(const CBase & ent)
               {
                     cout<<"CBase operator = ... "<<endl;
                     return *this;
                }
            };

            class CDerive: public CBase
            {
            public:
                 CDerive()
                 {
                       cout<<"CDerive constructing 
                 }
                 ~CDerive()
                 {
                        cout<<"CDerive destructing ..."<<endl;
                  } 
            public:
                 CDerive & operator=(const CDerive & ent)
                {
                       cout<<"CDerive operator = ... "<<endl;
                       return *this;
                 }
            }

            定義如下操作:

            CBase * b1 = new CDerive();
            CBase * b2 = new CDerive();

            (*b1) = (*b2);

            可以看到其輸出為:
            CBase constructing ...
            CDerive constructing ...
            CBase constructing ...
            CDerive constructing ...
            CBase operator = ...
            CDerive destructing ...
            CBase destructing ...
            CDerive destructing ...
            CBase destructing

            而實際上,操作(*b1) = (*b2)是想把b1,b2實際所指類型的兩個對象之間進行賦值,但是它只是調(diào)用了基類的賦值操作,沒有執(zhí)行其本身派生類的賦值操作。

            發(fā)現(xiàn)有兩種方法可以解決這個問題,如果能夠知道基類指針實際所指的是哪個派生類的的對象,直接類型轉(zhuǎn)換就可以了:

            (*((CDerive*)b1)) = (*((CDerive*)b2));

            這樣可以發(fā)現(xiàn)輸出了:CDerive operator = ... 。但是當要定義基類的指針的時候,往往隱藏了具體的派生類,即往往不知道指針到底實現(xiàn)的是哪個派生類,所以這種方法有很多局限性。

            這時候可以采用第二種方法,即在派生類中重載基類的賦值操作符,即首先把基類的operator=定義為virtual operator=,再在派生類中重載這個,如:

            CBase & operator=(const CBase & ent)
             {
                   const CDerive * p = reinterpret_cast<const CDerive *>(&ent);
                   return operator=((*p));
             }

            好的,當再執(zhí)行 (*b1) = (*b2) 的時候就可以看到輸出:CDerive operator = ... 。


             在此發(fā)現(xiàn)在派生類中重載派生類的operator =的時候,如果在基類中也重載operator = ,這樣會帶來很多麻煩,可能會丟失很多也許不想丟失的數(shù)據(jù)。
             
            同樣,依次還存在問題:
            CBase * b1 = new CDerive();
            CDervie * d1 = new CDerive();

            (*b1) = (*d1);

            CBase * b2 = new CBase ();
            CDervie * d2 = new CDerive();
            (*b2) = (*d2);

            所以我個人覺得,如果一個基類有很多個派生類的,而派生類中又重載了派生類本身的賦值操作符的時候,則基類中最好不要去重載賦值操作符,不如直接用函數(shù)去賦值。正如所說那樣,運算符重載只是為了一種語法上的方便,是另外一種函數(shù)調(diào)用方式,如果不能帶來方便,就沒必要了,還不如直接用函數(shù)去代替。


            .............敬請指點..................
            posted on 2006-05-22 01:09 erran 閱讀(1644) 評論(2)  編輯 收藏 引用 所屬分類: C & C++

            Feedback

            # re: C++隨筆 關(guān)于virtual operator = 2006-06-02 08:26 LOGOS
            嗯,在有繼承的體系中,重載賦值操作符的確會發(fā)生很多災難性的事情。
            增加知識了。  回復  更多評論
              

            # re: C++隨筆 關(guān)于virtual operator = 2009-11-23 13:58 Noock Tian
            CBase & operator=(const CBase & ent)
            {
            const CDerive * p = reinterpret_cast<const CDerive *>(&ent);
            return operator=((*p));
            }
            這個實現(xiàn)是有問題的,返回值應該是
            CDerived& operator=(const CDerived& other)
            {
            CBase::operator=(other);
            // Copy new members in CDerived
            return *this;
            }
              回復  更多評論
              

            久久精品嫩草影院| 亚洲色婷婷综合久久| 97r久久精品国产99国产精| 精品国产福利久久久| 国产高潮久久免费观看| 性做久久久久久久久| 久久久久AV综合网成人| 99热精品久久只有精品| 久久久噜噜噜久久中文字幕色伊伊 | 青青久久精品国产免费看| 伊人色综合久久天天人守人婷| 精品综合久久久久久97| 女人香蕉久久**毛片精品| 性高湖久久久久久久久AAAAA | 97久久国产亚洲精品超碰热| 国内精品伊人久久久久影院对白| 2021国产精品午夜久久| 精品久久久久久久| 欧美黑人激情性久久| 色综合久久综精品| 久久精品蜜芽亚洲国产AV| 久久亚洲av无码精品浪潮| 免费观看成人久久网免费观看| 麻豆久久久9性大片| 青青热久久国产久精品 | 国产成人精品久久免费动漫| 91久久成人免费| 亚洲午夜久久久影院| 国产精品成人99久久久久91gav| 久久久午夜精品| 欧美激情精品久久久久久久| 日本一区精品久久久久影院| 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 国产亚洲精久久久久久无码AV| 人妻无码中文久久久久专区| 久久国产亚洲精品| 亚洲第一永久AV网站久久精品男人的天堂AV | 久久国产精品成人片免费| 久久午夜夜伦鲁鲁片免费无码影视 | 精品久久久无码人妻中文字幕| 日韩AV毛片精品久久久|