• <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>
            看一下Ogre里面的ShagedPtr,其實(shí)就是一個(gè)Smart Pointers。下面的代碼是刪去了原有注釋的。現(xiàn)不談里面的MUTEX。

            #ifndef __SharedPtr_H__
            #define __SharedPtr_H__
            #include "OgrePrerequisites.h"
            namespace Ogre {
                template<class T> class SharedPtr {
                protected:
                    T* pRep;           
                    unsigned int* pUseCount; //看到這里,應(yīng)該能知道,SharedPtr是通過(guò)引用計(jì)數(shù)來(lái)管理pRep的壽命      
                public:
                    OGRE_AUTO_SHARED_MUTEX            
                    SharedPtr() : pRep(0), pUseCount(0)
                    {
                        OGRE_SET_AUTO_SHARED_MUTEX_NULL
                    }//允許有一個(gè)空的SharedPtr,不指向任何的對(duì)象。

                    template< class Y>
                    explicit SharedPtr(Y* rep) : pRep(rep), pUseCount(new unsigned int(1))
                    {
                        OGRE_SET_AUTO_SHARED_MUTEX_NULL
                        OGRE_NEW_AUTO_SHARED_MUTEX
                    }//這個(gè)寫法是Member Templates,很有用,這樣就允許用一個(gè)Y對(duì)象的指針來(lái)初始化一個(gè)SharedPtr<T>
                             //下面還能看到很多這樣的Member Templates
                             //要是以前沒(méi)見(jiàn)過(guò)的人,推薦看一下C++ Templates的第5章、第3節(jié)
                             //try this:   vector<int> intvec;
                             //       vector<float> floatvec;
                             //       floatvec = intvec ???????
                             //提一下,所有的初始化函數(shù)都沒(méi)有檢查rep是否非空,所以SharedPtr接受一個(gè)Null指針
                             //安全檢查在每次調(diào)用的時(shí)候
                             //這里還使用了關(guān)鍵字explicit,禁止了隱式轉(zhuǎn)換

                    SharedPtr(const SharedPtr& r)
                        : pRep(0), pUseCount(0)
                    {
                        OGRE_SET_AUTO_SHARED_MUTEX_NULL
                        OGRE_MUTEX_CONDITIONAL(r.OGRE_AUTO_MUTEX_NAME)
                        {
                            OGRE_LOCK_MUTEX(*r.OGRE_AUTO_MUTEX_NAME)
                            OGRE_COPY_AUTO_SHARED_MUTEX(r.OGRE_AUTO_MUTEX_NAME)
                            pRep = r.pRep; //注意下與后面的不同
                            pUseCount = r.pUseCount;
                            // Handle zero pointer gracefully to manage STL containers
                            if(pUseCount)
                            {
                                ++(*pUseCount); 
                            }
                        }
                    }

                    SharedPtr& operator=(const SharedPtr& r) {
                        if (pRep == r.pRep)
                            return *this;
                        SharedPtr<T> tmp(r);
                        swap(tmp);
                        return *this;
                    }//這里的寫法有點(diǎn)意思,本來(lái)在pRep指向r.pRep之前對(duì)pRep做一次release,
                             //但是這里沒(méi)看到,其實(shí)是通過(guò)tmp這個(gè)局部變量的自動(dòng)解析實(shí)現(xiàn)的。
                    template< class Y>
                    SharedPtr(const SharedPtr<Y>& r)
                        : pRep(0), pUseCount(0)
                    {
                        OGRE_SET_AUTO_SHARED_MUTEX_NULL
                        OGRE_MUTEX_CONDITIONAL(r.OGRE_AUTO_MUTEX_NAME)
                        {
                            OGRE_LOCK_MUTEX(*r.OGRE_AUTO_MUTEX_NAME)
                            OGRE_COPY_AUTO_SHARED_MUTEX(r.OGRE_AUTO_MUTEX_NAME)
                            pRep = r.getPointer(); //這里用的是函數(shù),和上面那個(gè)的區(qū)別??
                            pUseCount = r.useCountPointer();
                            // Handle zero pointer gracefully to manage STL containers
                            if(pUseCount)
                            {
                                ++(*pUseCount);
                            }
                        }
                    }
                    template< class Y>
                    SharedPtr& operator=(const SharedPtr<Y>& r) {
                        if (pRep == r.pRep)
                            return *this;
                        SharedPtr<T> tmp(r);
                        swap(tmp);
                        return *this;
                    }
                    virtual ~SharedPtr() {
                        release();
                    }
                    inline T& operator*() const { assert(pRep); return *pRep; }
                    inline T* operator->() const { assert(pRep); return pRep; }
                            //在用的時(shí)候檢查pRep的合法性
                    inline T* get() const { return pRep; }
                    void bind(T* rep) {
                        assert(!pRep && !pUseCount);
                        OGRE_NEW_AUTO_SHARED_MUTEX
                        OGRE_LOCK_AUTO_SHARED_MUTEX
                        pUseCount = new unsigned int(1);
                        pRep = rep;
                    }
                    inline bool unique() const { OGRE_LOCK_AUTO_SHARED_MUTEX assert(pUseCount); return *pUseCount == 1; }
                    inline unsigned int useCount() const { OGRE_LOCK_AUTO_SHARED_MUTEX assert(pUseCount); return *pUseCount; }
                    inline unsigned int* useCountPointer() const { return pUseCount; }
                    inline T* getPointer() const { return pRep; }
                    inline bool isNull(void) const { return pRep == 0; }
                    inline void setNull(void) {
                        if (pRep)
                        {
                            // can't scope lock mutex before release incase deleted
                            release();
                            pRep = 0;
                            pUseCount = 0;
                        }
                    }

                protected:

                    inline void release(void)
                    {
                        bool destroyThis = false;
                        OGRE_MUTEX_CONDITIONAL(OGRE_AUTO_MUTEX_NAME)
                        {
                            OGRE_LOCK_AUTO_SHARED_MUTEX
                            if (pUseCount)
                            {
                                if (--(*pUseCount) == 0)
                                {
                                    destroyThis = true;
                                }
                            }
                        }
                        if (destroyThis)
                            destroy();

                        OGRE_SET_AUTO_SHARED_MUTEX_NULL
                    }

                    virtual void destroy(void)
                    {
                        delete pRep;
                        delete pUseCount;
                        OGRE_DELETE_AUTO_SHARED_MUTEX
                    }

                    virtual void swap(SharedPtr<T> &other)
                    {
                        std::swap(pRep, other.pRep);
                        std::swap(pUseCount, other.pUseCount);
            #if OGRE_THREAD_SUPPORT
                        std::swap(OGRE_AUTO_MUTEX_NAME, other.OGRE_AUTO_MUTEX_NAME);
            #endif
                    }
                };

                template<class T, class U> inline bool operator==(SharedPtr<T> const& a, SharedPtr<U> const& b)
                {
                    return a.get() == b.get();
                }

                template<class T, class U> inline bool operator!=(SharedPtr<T> const& a, SharedPtr<U> const& b)
                {
                    return a.get() != b.get();
                }
            }
            #endif
            最后有注意到:
                inline T* get() const { return pRep; }
                inline T* getPointer() const { return pRep; }
            不知道為啥要這樣,有一個(gè)不就行了么。
            更多的細(xì)節(jié)、使用方法放到下次把。

            Feedback

            # re: Ogre中的Smart Pointers——SharedPtr  回復(fù)  更多評(píng)論   

            2008-11-13 19:35 by imdavid
            看的糊涂...

            # re: Ogre中的Smart Pointers——SharedPtr  回復(fù)  更多評(píng)論   

            2008-12-13 22:39 by 李錦俊
            SharedPtr是Smart Pointers的一種,Smart Pointers還有好多其他類型。

            inline T* get() const { return pRep; }
            inline T* getPointer() const { return pRep; }

            這估計(jì)是為了照顧不同使用者的習(xí)慣,哈。有的人喜歡用get(認(rèn)為更簡(jiǎn)練),有的人喜歡用getPointer(認(rèn)為意義更清晰)

            # re: Ogre中的Smart Pointers——SharedPtr  回復(fù)  更多評(píng)論   

            2009-02-12 09:42 by mycode
            建議博主,詳細(xì)解釋一下SharedPtr與其他智能指針的區(qū)別,及使用場(chǎng)合。

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


            posts - 2, comments - 4, trackbacks - 0, articles - 0

            Copyright © 空心菜

            国产精品久久久久久久app | 伊人久久大香线蕉亚洲| 久久久久国产一区二区三区| 麻豆国内精品久久久久久| 久久婷婷人人澡人人爽人人爱| 99精品久久久久久久婷婷 | 亚洲欧美久久久久9999 | 人人狠狠综合久久亚洲高清| 亚洲精品无码久久千人斩| 91精品国产高清久久久久久国产嫩草| 狠狠色综合久久久久尤物| 日本五月天婷久久网站| 久久午夜电影网| 亚洲人成伊人成综合网久久久| 久久久久久久综合日本亚洲| 精品人妻伦九区久久AAA片69| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 狠狠综合久久综合中文88| 中文字幕久久久久人妻| 韩国三级中文字幕hd久久精品 | 久久这里的只有是精品23| 99久久99这里只有免费的精品| 久久笫一福利免费导航| 99久久精品免费| 国产一级做a爰片久久毛片| 亚洲中文字幕久久精品无码APP| 久久久精品国产亚洲成人满18免费网站 | 日韩十八禁一区二区久久| 成人午夜精品久久久久久久小说| 久久精品无码专区免费东京热| 18禁黄久久久AAA片| 亚洲欧美日韩精品久久亚洲区| 久久亚洲国产精品123区| 久久久精品免费国产四虎| 国产精品久久久久国产A级| 一本一道久久综合狠狠老| 亚洲国产成人精品91久久久 | 热久久这里只有精品| 色欲综合久久中文字幕网| 久久香蕉国产线看观看精品yw| 久久精品aⅴ无码中文字字幕不卡 久久精品成人欧美大片 |