• <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++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              106 Posts :: 1 Stories :: 97 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(12)

            搜索

            •  

            積分與排名

            • 積分 - 177261
            • 排名 - 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實際所指類型的兩個對象之間進行賦值,但是它只是調用了基類的賦值操作,沒有執行其本身派生類的賦值操作。

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

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

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

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

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

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


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

            (*b1) = (*d1);

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

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


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

            Feedback

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

            # re: C++隨筆 關于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));
            }
            這個實現是有問題的,返回值應該是
            CDerived& operator=(const CDerived& other)
            {
            CBase::operator=(other);
            // Copy new members in CDerived
            return *this;
            }
              回復  更多評論
              

            久久精品亚洲乱码伦伦中文| 日韩欧美亚洲综合久久影院Ds| 亚洲欧美日韩中文久久| 欧美日韩精品久久久久| 久久久久久九九99精品| 青青青青久久精品国产h| 99久久免费国产精品特黄| 久久精品国产亚洲av水果派 | 人妻久久久一区二区三区| 国产成人无码精品久久久免费| 亚洲美日韩Av中文字幕无码久久久妻妇 | 亚洲精品99久久久久中文字幕 | 99久久精品这里只有精品 | 日韩精品久久久久久久电影蜜臀 | 婷婷综合久久狠狠色99h| 精品伊人久久久| 国产精品久久久久久久午夜片| 久久亚洲精品人成综合网| 三级韩国一区久久二区综合| 好属妞这里只有精品久久| 国产美女亚洲精品久久久综合| 久久人人爽人人爽人人片AV麻豆| 99久久婷婷免费国产综合精品| 国产激情久久久久久熟女老人| 亚洲午夜久久久| 亚洲性久久久影院| 亚洲精品无码久久不卡| 香蕉99久久国产综合精品宅男自 | 国产综合成人久久大片91| 日韩人妻无码一区二区三区久久| 久久福利资源国产精品999| 久久国产美女免费观看精品 | 狠狠精品干练久久久无码中文字幕| 国产成人久久精品区一区二区| 欧美牲交A欧牲交aⅴ久久| 精品久久久久久无码专区不卡| 亚洲AV日韩精品久久久久| 久久久老熟女一区二区三区| 久久久久久久久无码精品亚洲日韩 | 色欲久久久天天天综合网精品 | 久久无码人妻一区二区三区午夜|