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

            久久青青草原国产精品免费 | 91麻豆精品国产91久久久久久| 亚洲精品美女久久久久99| 亚洲中文字幕无码一久久区| 久久精品无码专区免费青青| 久久AV高清无码| 人妻少妇久久中文字幕| 亚洲va久久久噜噜噜久久天堂| 一本久久久久久久| 久久久久亚洲AV成人网人人网站| 久久精品无码免费不卡| 亚洲精品无码久久久| 久久天天躁夜夜躁狠狠躁2022| 亚洲中文久久精品无码| 精品久久久久久无码专区不卡| 久久精品国产半推半就| 91精品国产综合久久香蕉| 久久97久久97精品免视看秋霞| 久久笫一福利免费导航 | 欧美综合天天夜夜久久| 99精品久久精品| 国产成人精品久久亚洲高清不卡| 亚洲成色WWW久久网站| 久久久青草青青国产亚洲免观| 999久久久免费国产精品播放| 久久精品成人| 性欧美大战久久久久久久久| 国产精品久久久久久久久| 久久久青草青青国产亚洲免观| 久久精品国产免费观看三人同眠| 久久国产精品99久久久久久老狼| 久久久久久国产a免费观看黄色大片 | 色欲综合久久躁天天躁蜜桃| 91久久精品国产91性色也| 久久久精品日本一区二区三区| 亚洲精品无码久久一线| 久久婷婷色综合一区二区| 久久国产精品一区二区| 久久天天躁狠狠躁夜夜不卡| 性做久久久久久久久| 国产99久久精品一区二区|