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


            av无码久久久久久不卡网站| 久久只这里是精品66| 九九久久99综合一区二区| 人妻无码久久一区二区三区免费| 国产99久久精品一区二区| 2021少妇久久久久久久久久| 日韩精品久久久肉伦网站| 香港aa三级久久三级老师2021国产三级精品三级在 | 久久这里只有精品18| 午夜精品久久久久久久久| 久久e热在这里只有国产中文精品99| 久久久久波多野结衣高潮| 91久久精一区二区三区大全| 男女久久久国产一区二区三区| 91精品国产综合久久精品| 狠狠色丁香婷婷综合久久来来去| 性做久久久久久免费观看| 久久久无码精品亚洲日韩按摩| 久久国产乱子伦精品免费强| 精品久久久久久无码人妻热| 少妇无套内谢久久久久| 99久久99久久精品免费看蜜桃| 久久亚洲高清综合| 亚洲欧美日韩精品久久| 久久影院综合精品| 国产精品免费福利久久| 99久久亚洲综合精品网站| 精品久久久久久成人AV| 一本色道久久综合狠狠躁篇| 亚洲精品乱码久久久久久蜜桃不卡 | 久久人人爽人人爽人人av东京热| 91久久精一区二区三区大全| 久久久久久久久久久免费精品| 97久久精品人妻人人搡人人玩| 三上悠亚久久精品| 久久久久久综合网天天| 欧美色综合久久久久久| 欧美亚洲另类久久综合| 91精品国产高清91久久久久久| 久久久久久伊人高潮影院| 国内精品伊人久久久久网站|