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

            martin

            thinking

            常用鏈接

            統(tǒng)計

            software

            最新評論

            智能指針的代碼實例

            前段時間,寫了一點關(guān)于智能指針的東西,有讀者反映沒有代碼比較難懂.現(xiàn)給出源碼,并稍微加以解釋.

            智能指針類用到的基類的定義:
            template<typename T>
            class HandleBase
            {
            public:

                typedef T element_type;

                T* get() const
                {
                    return _ptr;
                }
               
               //重載->操作符,返回所指對象的指針.

                T* operator->() const
                {
                    if(!_ptr)
                    {
                        //
                        // We don't throw directly NullHandleException here to
                        // keep the code size of this method to a minimun (the
                        // assembly code for throwing an exception is much bigger
                        // than just a function call). This maximises the chances
                        // of inlining by compiler optimization.
                        //
                        throwNullHandleException(__FILE__, __LINE__);
                    }

                    return _ptr;
                }

            //  通過智能指針獲取所指對象的引用.

                T& operator*() const
                {
                    if(!_ptr)
                    {
                        //
                        // We don't throw directly NullHandleException here to
                        // keep the code size of this method to a minimun (the
                        // assembly code for throwing an exception is much bigger
                        // than just a function call). This maximises the chances
                        // of inlining by compiler optimization.
                        //
                        throwNullHandleException(__FILE__, __LINE__);
                    }

                    return *_ptr;
                }

                operator bool() const
                {
                    return _ptr ? true : false;
                }

                void swap(HandleBase& other)
                {
                    std::swap(_ptr, other._ptr);
                }

                T* _ptr;

            private:

                void throwNullHandleException(const char *, int) const;
            };

            ......


            // 智能指針類定義

            template<typename T>
            class Handle : public HandleBase<T>
            {
            public:

                Handle(T* p = 0)               //智能指針的構(gòu)造函數(shù)
                {
                    this->_ptr = p;

                    if(this->_ptr)
                    {
                        this->_ptr->__incRef();         //在構(gòu)造函數(shù)中增加所指對象的引用計數(shù)
                    }
                }

                template<typename Y>                  //拷貝構(gòu)造函數(shù)
                Handle(const Handle<Y>& r)
                {
                    this->_ptr = r._ptr;

                    if(this->_ptr)
                    {
                        this->_ptr->__incRef();   //在構(gòu)造函數(shù)中增加所指對象的引用計數(shù)
                    }
                }

                Handle(const Handle& r)         //拷貝構(gòu)造函數(shù)
                {
                    this->_ptr = r._ptr;

                    if(this->_ptr)
                    {
                        this->_ptr->__incRef();    //在構(gòu)造函數(shù)中增加所指對象的引用計數(shù)
                    }
                }

                ~Handle()
                {
                    if(this->_ptr)
                    {
                        this->_ptr->__decRef();      //在析構(gòu)函數(shù)中減少所指對象的引用計數(shù)
                    }
                }

            // 重載=操作符, 要注意所有權(quán) (即,對原實例的處理).

                Handle& operator=(T* p)         
                {
                    if(this->_ptr != p)
                    {
                        if(p)
                        {
                            p->__incRef();      //增加新指對象的引用計數(shù)
                        }

                        T* ptr = this->_ptr;
                        this->_ptr = p;

                        if(ptr)
                        {
                            ptr->__decRef();   //減少原來所指對象的引用計數(shù)
                        }
                    }
                    return *this;
                }

                template<typename Y>
                Handle& operator=(const Handle<Y>& r)
                {
                    if(this->_ptr != r._ptr)
                    {
                        if(r._ptr)
                        {
                            r._ptr->__incRef();   //增加新指對象的引用計數(shù)
                        }

                        T* ptr = this->_ptr;
                        this->_ptr = r._ptr;

                        if(ptr)
                        {
                            ptr->__decRef();      //減少原來所指對象的引用計數(shù)
                        }
                    }
                    return *this;
                }

                Handle& operator=(const Handle& r)
                {
                    if(this->_ptr != r._ptr)
                    {
                        if(r._ptr)
                        {
                            r._ptr->__incRef();            //增加新指對象的引用計數(shù)
                        }

                        T* ptr = this->_ptr;
                        this->_ptr = r._ptr;

                        if(ptr)
                        {
                            ptr->__decRef();            //減少原來所指對象的引用計數(shù)
                        }
                    }
                    return *this;
                }

             跟智能指針配合使用的對象.要能夠跟指針智能配合使用,這些對象應(yīng)該是從下列類的派生類的實例.
            class SimpleShared
            {
            public:

                SimpleShared();
                SimpleShared(const SimpleShared&);

                virtual ~SimpleShared()
                {
                }

                SimpleShared& operator=(const SimpleShared&)
                {
                    return *this;
                }

                void __incRef()
                {
                    assert(_ref >= 0);
                    ++_ref;
                }

                void __decRef()
                {
                    assert(_ref > 0);
                    if(--_ref == 0)               // 如果引用計數(shù)為0,則摧毀對象本身.
                    {
                        if(!_noDelete)
                        {
                            _noDelete = true;
                            delete this;
                        }
                    }
                }

                int __getRef() const
                {
                    return _ref;
                }

                void __setNoDelete(bool b)
                {
                    _noDelete = b;
                }

            private:

                int _ref;
                bool _noDelete;
            };

            class Shared
            {
            public:

                Shared();
                Shared(const Shared&);

                virtual ~Shared()
                {
                }

                Shared& operator=(const Shared&)
                {
                    return *this;
                }

                virtual void __incRef();
                virtual void __decRef();
                virtual int __getRef() const;
                virtual void __setNoDelete(bool);

            protected:

            #if defined(_WIN32)
                LONG _ref;
            #elif defined(ICE_HAS_ATOMIC_FUNCTIONS)
                volatile int _ref;
            #else
                int _ref;
                Mutex _mutex;
            #endif
                bool _noDelete;
            };

            posted on 2009-03-09 16:07 martin_yahoo 閱讀(2226) 評論(6)  編輯 收藏 引用

            評論

            # re: 智能指針的代碼實例 2009-03-09 17:18 eXile

            ICE中的實現(xiàn)吧,這個并沒有解決循環(huán)引用的問題。所以他還有一個GCShared   回復(fù)  更多評論   

            # re: 智能指針的代碼實例[未登錄] 2009-03-09 18:01 martin_yahoo

            u r right. These souce code is abstracted from ICE.  回復(fù)  更多評論   

            # re: 智能指針的代碼實例 2009-03-11 09:45 夢在天涯

            mark  回復(fù)  更多評論   

            # re: 智能指針的代碼實例 2009-05-05 09:02 brightcoder

            一個句柄類而已  回復(fù)  更多評論   

            # re: 智能指針的代碼實例 2013-04-26 23:58 WWW

            這是哪個開源項目中的啊?  回復(fù)  更多評論   

            # re: 智能指針的代碼實例 2013-06-08 17:13 tb

            模仿寫一下  回復(fù)  更多評論   


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            精品久久久久久久中文字幕| 久久九九久精品国产免费直播| 久久国产成人午夜aⅴ影院| 久久丫精品国产亚洲av| 欧美亚洲另类久久综合婷婷| 青青草国产精品久久久久| 国产精品久久久久久影院| 久久久久久久久久久久中文字幕 | 久久久久久久国产免费看| 亚洲国产成人久久综合碰碰动漫3d| 精品久久久久久中文字幕人妻最新| 蜜桃麻豆WWW久久囤产精品| 色妞色综合久久夜夜| 综合人妻久久一区二区精品| 亚洲级αV无码毛片久久精品| 久久天天躁狠狠躁夜夜躁2O2O| 无码人妻少妇久久中文字幕蜜桃| 日韩av无码久久精品免费| 国内精品久久久久影院优| 99久久精品免费看国产免费| 久久久久久国产精品免费免费| 欧美亚洲国产精品久久高清| 色综合久久中文字幕无码| 久久精品中文字幕久久| 人人狠狠综合久久亚洲| 无码日韩人妻精品久久蜜桃| 精品999久久久久久中文字幕| 久久久精品国产亚洲成人满18免费网站| 亚洲午夜福利精品久久| 麻豆成人久久精品二区三区免费| 久久96国产精品久久久| 香蕉久久永久视频| 国产成人久久精品一区二区三区| 999久久久无码国产精品| 国产69精品久久久久9999| 久久久无码精品亚洲日韩京东传媒| 久久久久亚洲AV无码麻豆| 欧美日韩成人精品久久久免费看| 久久天天躁狠狠躁夜夜躁2O2O | 久久久久亚洲AV无码专区桃色| 久久久久se色偷偷亚洲精品av|