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

            jake1036

            賦值操作符相關

                                                         賦值操作符相關

              一 令operator = 返回一個reference * this

            1  先看一個遵循的標準協議
                
            class Widget
            {
              
            public :
                Widget::
            operator=(const Widget & rhs)
                


                  
            return * this ; //返回一個左側對象
                }


            }


             2 不光適用于標準形式,也適應于所有的賦值操作
                比如適應于 += , -= ,*= 
                
               綜上: 令賦值操作符返回一個reference to * this 。



             二 在operator= 中處理 自我賦值

              考慮下面的代碼:
              

            Widget & Widget::operator=(const Widget & rhs)
            {
              delete pb ; 
              pb 
            = new Bitmap(*rhs.pb) ; 
              
            return * this ;
            }

             上述代碼有一個問題,當實現自我賦值的時候,pb對象已經被刪除,此時又根據pb對象創建一個新的對象,造成錯誤。

             解決方法一:
              在刪除之前添加一個證同測試:
              代碼如下:
             

            Widget & Widget::operator=(const Widget & rhs)
            {
              
            if(&rhs == this)
                
            return *this;
              
              delete pb ;
              pb 
            = new Widget(rhs.pb) ; //此處發生錯誤
              return *this ; 
            }

             但是上述代碼若new 代碼處發生異常,則很可能導致返回一個指向已刪除內存區域的指針。

            解決方法2:
            可以先創建一個新的pb,然后再對舊pb進行刪除。

            Widget & Widget::operator=(const Widget & rfs)
            {
              
            if(this == &rfs)
                
            return *this ;   
               Bitmap 
            * ptr = pb ;
               pb 
            = new Bitmap(rfs.pb);
               delete ptr ;
               
            return *this;
            }


            解決方法3:
              使用copy and swap 技術
             
              


            void swap(Widget & rhs)

            Widget 
            & Widget::operator = (const Widget & rhs)
            {
              Widget temp(rhs) ;
              swap(temp) ;
              
            return * this ; 
            }







             

            posted on 2011-05-06 22:22 kahn 閱讀(250) 評論(0)  編輯 收藏 引用

            亚洲人成精品久久久久| 欧美久久天天综合香蕉伊| 国产精品久久久久jk制服| 中文字幕一区二区三区久久网站 | 久久精品国产一区二区三区| 色99久久久久高潮综合影院| 久久人人爽人人爽人人AV| AAA级久久久精品无码区| 久久中文字幕精品| 久久国产精品99精品国产987| 久久一区二区三区99| 久久精品无码一区二区无码| 久久精品国产第一区二区| 国产亚洲精品美女久久久| 无码任你躁久久久久久久| 青青青青久久精品国产 | 久久精品无码av| 亚洲国产精品无码久久一线| 久久精品综合一区二区三区| 久久亚洲精精品中文字幕| 久久天天躁狠狠躁夜夜avapp| 99久久精品无码一区二区毛片| 中文国产成人精品久久不卡| 久久久久久极精品久久久| 女人香蕉久久**毛片精品| 久久亚洲欧美国产精品| 日韩av无码久久精品免费| 精品综合久久久久久97| 国产69精品久久久久久人妻精品| 精品人妻伦九区久久AAA片69| 久久美女网站免费| 91久久精品91久久性色| 东京热TOKYO综合久久精品| 少妇高潮惨叫久久久久久| 亚洲国产欧美国产综合久久| 久久精品国产亚洲av麻豆蜜芽 | 精品熟女少妇aⅴ免费久久| 国产精品99久久久久久宅男 | 一级做a爰片久久毛片看看 | 色偷偷88888欧美精品久久久| 精品国产乱码久久久久软件|