• <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 閱讀(252) 評論(0)  編輯 收藏 引用

            无码国内精品久久人妻| 久久国产乱子伦精品免费强| 色综合久久综合网观看| 久久国产乱子精品免费女| 精品久久久久久中文字幕| 色综合久久88色综合天天| 天天做夜夜做久久做狠狠| 亚洲欧美日韩中文久久| 国产亚洲欧美成人久久片| 久久这里只有精品视频99| 久久久久亚洲AV无码麻豆| 久久99国产一区二区三区| 伊人久久精品无码二区麻豆| 国产 亚洲 欧美 另类 久久| 久久亚洲精品人成综合网| 人妻无码精品久久亚瑟影视 | 99久久精品免费看国产一区二区三区 | 一级做a爱片久久毛片| 亚洲精品NV久久久久久久久久| 91久久国产视频| 久久免费看黄a级毛片| 区久久AAA片69亚洲| 亚洲一区中文字幕久久| 亚洲精品国产美女久久久| 亚洲精品久久久www| 国产精品丝袜久久久久久不卡| 久久久久久午夜成人影院| 久久久午夜精品福利内容| 亚洲国产成人久久精品99 | 精品久久久久久无码中文野结衣 | 人人狠狠综合久久亚洲| 99久久精品国产高清一区二区| avtt天堂网久久精品| 日韩久久久久久中文人妻| 无码人妻少妇久久中文字幕| 91久久福利国产成人精品| 99久久精品国产综合一区| 一级做a爱片久久毛片| A级毛片无码久久精品免费| 中文字幕亚洲综合久久| 久久91精品国产91久久麻豆|