• <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)  編輯 收藏 引用

            精品综合久久久久久97超人 | 亚洲精品高清国产一线久久| 国产精品美女久久久m| 亚洲国产精品久久| 亚洲中文字幕久久精品无码喷水| 久久综合狠狠综合久久| 久久久久久久久久久精品尤物 | 99久久精品免费看国产一区二区三区| 久久国产亚洲精品麻豆| 久久人做人爽一区二区三区| 武侠古典久久婷婷狼人伊人| av无码久久久久不卡免费网站| 久久夜色精品国产亚洲| 国产成人精品久久免费动漫| 久久久久女人精品毛片| 欧美一级久久久久久久大片| 久久精品中文字幕有码| 国内精品伊人久久久久影院对白| 亚洲国产精品久久久久久| 国产成人99久久亚洲综合精品| 久久精品一区二区| 狠狠色综合久久久久尤物 | 久久午夜羞羞影院免费观看| 久久综合给合久久狠狠狠97色| 久久精品国产网红主播| 久久精品国产一区二区电影| 久久99免费视频| 国内精品久久久久久久久| 久久久久久亚洲精品不卡 | 久久精品a亚洲国产v高清不卡| 国产精品热久久毛片| 久久国产亚洲精品麻豆| 国产激情久久久久影院小草| 久久久久人妻一区精品性色av| 伊人伊成久久人综合网777| 久久精品国产第一区二区三区| 久久se这里只有精品| 欧美伊香蕉久久综合类网站| 国产A级毛片久久久精品毛片| 国产福利电影一区二区三区久久老子无码午夜伦不 | 国色天香久久久久久久小说|