• <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 閱讀(2238) 評論(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   管理


            91秦先生久久久久久久| 久久99精品久久久久久动态图| 欧美久久综合性欧美| 亚洲伊人久久成综合人影院 | 亚洲国产精品久久久天堂| 久久国产精品久久精品国产| 久久婷婷五月综合国产尤物app| 久久精品国产亚洲av高清漫画| 中文字幕久久精品 | 国产精品无码久久综合网| 亚洲综合日韩久久成人AV| 久久人人青草97香蕉| 久久久久亚洲AV综合波多野结衣| 99久久精品费精品国产一区二区| 亚洲国产精品无码久久| 国产成人久久精品二区三区| 日本欧美久久久久免费播放网| 久久久久亚洲AV成人网人人网站| 一本色道久久88加勒比—综合| 国产精品久久久久久久久软件| 香蕉久久夜色精品国产尤物| 欧美一区二区精品久久| 国产亚洲欧美精品久久久| 亚洲欧洲日产国码无码久久99| 久久精品国产一区二区| 中文字幕无码久久久| 久久激情五月丁香伊人| 99久久精品免费观看国产| 久久精品www| AA级片免费看视频久久| 久久亚洲国产欧洲精品一| 国产精品99久久久久久人| 国产精品美女久久久久网| 亚洲精品无码久久千人斩| 一本久久知道综合久久| 一本色道久久综合狠狠躁| 亚洲精品国精品久久99热一| 亚洲色欲久久久综合网| 欧美午夜精品久久久久免费视| 亚洲色欲久久久综合网东京热| 久久精品无码一区二区无码|