• <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ⅴ激情无码久久| 亚洲国产精品18久久久久久| 久久99精品久久久久子伦| 国产精品无码久久综合| aaa级精品久久久国产片| 久久综合给久久狠狠97色| 性做久久久久久久久浪潮| 国产精品美女久久久久| 久久超乳爆乳中文字幕| 亚洲国产欧美国产综合久久| 伊人伊成久久人综合网777| 久久WWW免费人成—看片| 久久亚洲欧美日本精品| 日本久久久精品中文字幕| 欧美精品一本久久男人的天堂| 国产免费久久久久久无码| 国产亚洲色婷婷久久99精品| 久久综合亚洲色HEZYO社区| 日本精品久久久久中文字幕8| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 91精品国产综合久久四虎久久无码一级| 精品久久久久中文字| 成人久久久观看免费毛片| 国色天香久久久久久久小说| 亚洲国产视频久久| 一本久久知道综合久久| 久久亚洲私人国产精品| 亚洲欧美国产日韩综合久久| 久久伊人精品一区二区三区| 国产精品一久久香蕉产线看| 亚洲精品无码久久毛片| 久久99国产综合精品| 久久久久噜噜噜亚洲熟女综合| 久久久久久国产精品免费无码| 久久99精品国产麻豆宅宅| 久久精品国产免费一区| 午夜精品久久久久| 久久久久国产| 久久精品成人免费国产片小草|