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

            大龍的博客

            常用鏈接

            統計

            最新評論

            智能指針重載operator ->()、自賦值、引用計數 -- 轉

            智能指針(smart pointers),是一種加限制的近委托機制(相當于老師的管理),其中包含普通指針(相當于學生的自主)。它將指針對象化,返回X類指針控制X類型對象(通常顯式含有一個X類型指針成員);優點在于X類指針成員共享內存分配,可防懸掛,采用引用計數,無指針指向時才析構。

            當然,也可在定義拷貝賦值時分配新存儲空間,使不共享,就完全無此問題。但此時需重定義分配內存的構造函數與拷貝構造函數,對賦值函數不需改變,也無須檢測自賦值(因為沒有delete語句)。e.g.:

                   class String{                 //上級管理類,物業!

            struct Srep;                  //包含類的聲明

            Srep *rep;                    //內含普通類指針,被管理

            Srep * operator->();             //返回Srep指針

            //……

            }

            重載operator->(),返回普通對象指針,稱為間接(Dereferencing),可形成“智能指針”機制。這樣方便操作,也可不用。對于Invoker->member;,operator ->為一元后綴運算符,可作兩種解釋:

            ①Invoker為指針,將尋找緊隨其后的類成員(或函數)標識符,找不到就出錯,這也是最常見的用法。

            ②Invoker為(定義的智能指針)對象,將解釋為(Invoker.operator->())->member。若Invoker類未重載operator->()則出錯;重載了X operator ->()時,如果返回類型X為指針,則進入①狀態;如果返回值類型仍為對象,再進入②狀態,判斷是否可循環。

            返回值應該為兩種:①指針,并找到成員標志符;②定義了operator->()的對象,將循環迭代。否則出錯。具體示例見于《C++ Primer》14.6節與《C++ Programming Language》11.10章節。迭代器就是一個很好的佐證,如vector<int> vec;中,定義了vector::iterator,返回值的指針類型為int。即有(*vec.begin())為int型。

            自賦值的危害:可參考《廿六、賦值函數重載與拷貝構造函數(百度百科ZT)》

            =運算符(assignment)為其左操作數配置新動態資源(free store)前,通常先將原先的動態資源析構,以防止內存泄漏(現在不釋放,以后就沒機會了)。如為自賦值,將丟失這部分信息,造成指針掛起。需檢查是否為自賦值,如果是就返回*this;否則,釋放原有資源,以獲得新資源!

            通常用檢測其指針是否相等即可(比較this與新值的指針,而非它們指向的值)。e.g.:

            A operator=(const A &Other){if(this==&Other) return *this;} //不是if(*this == other)

            智能指針采用引用計數(reference cout)來決定是否析構共享,常定義于受管理類中。《C++ Primer》對引用計數的描述:每次創建類的新對象時,初始化指針并將使用計數置為1。當對象作為另一對象的副本而創建時,復制構造函數復制指針并增加與之相應的使用計數的值。對一個對象進行賦值時,賦值操作符減少左操作數所指對象的使用計數的值(如果使用計數減至0,則刪除對象),并增加右操作數所指對象的使用計數的值。(反過來說更好)最后,調用析構函數時,析構函數減少使用計數的值,如果計數減至0,則刪除基礎對象。

            拷貝賦值時,常先增加右操作數計數,再減少左操作數計數,并判斷刪除動態存儲。可防止自身賦值,如為自賦值,引用計數肯定非0,相當于加1后立即減1,不會錯刪;反之可能出--n=0。《C++ Primer》13.5.1與《C++程序設計》11.12節均采用的此種方法。

            posted on 2010-05-08 12:29 大龍 閱讀(1296) 評論(0)  編輯 收藏 引用

            99久久精品九九亚洲精品| 色婷婷久久综合中文久久蜜桃av| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 国产999精品久久久久久| 欧美久久久久久午夜精品| 狠狠人妻久久久久久综合| 久久午夜羞羞影院免费观看| 狠狠色丁香久久综合婷婷| 久久经典免费视频| 91麻精品国产91久久久久| 日本五月天婷久久网站| 久久久噜噜噜久久中文字幕色伊伊| 久久天天躁夜夜躁狠狠躁2022| 国内精品久久久久久中文字幕| 性欧美大战久久久久久久久 | 999久久久国产精品| 久久亚洲AV无码精品色午夜| 日本免费久久久久久久网站| www久久久天天com| 国产精品一久久香蕉国产线看| 亚洲AV乱码久久精品蜜桃| 久久伊人中文无码| 91久久精品视频| 久久99国产亚洲高清观看首页| 伊人色综合久久天天人手人婷| 亚洲中文字幕久久精品无码喷水| 久久精品国产清自在天天线| 国产精品久久久99| 精品国产福利久久久| 久久香蕉国产线看观看精品yw| 中文无码久久精品| 久久国产欧美日韩精品| 久久久亚洲裙底偷窥综合| 亚洲欧美日韩精品久久亚洲区 | 丰满少妇高潮惨叫久久久| 狠狠色丁香久久婷婷综合| 久久无码中文字幕东京热| 久久亚洲日韩看片无码| 人妻丰满AV无码久久不卡| 国产精品99久久99久久久| 亚洲综合久久综合激情久久|