• <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>
            隨筆-6  評論-0  文章-16  trackbacks-0

            ??????有了CComObjectRootBase、CComObjectRootEx和線程模型特征類這些基礎(chǔ)原料,CComObject和它的伙伴們便可以自由的發(fā)揮它們的想象了。

            1.CComObject —— 普通堆對象??????
            ???下面是精簡的CComObject模板類的定義:??????

            template? < class ?Base >
            class ?CComObject?:? public ?Base
            {
            public :
            ????CComObject(
            void * ? = ?NULL)? throw ()
            ????{
            ????????_pAtlModule
            -> Lock();
            ????}
            ????
            ????virtual ? ~ CComObject()? throw ()
            ????{
            ????????FinalRelease();
            ??????? _pAtlModule -> Unlock();
            ????}
            ????
            ??? STDMETHOD_(ULONG,?AddRef)()?{ return ?InternalAddRef();}
            ????STDMETHOD_(ULONG,?Release)()
            ????{
            ????????ULONG?l?
            = ?InternalRelease();
            ????????
            if ?(l? == ? 0 )
            ????????????delete?
            this ;
            ????????
            return ?l;
            ????}
            ????
            ????STDMETHOD(QueryInterface)(REFIID?iid,? void ? ** ?ppvObject)? throw ()
            ????{
            return ?_InternalQueryInterface(iid,?ppvObject);}
            ????

            ????
            static ?HRESULT?WINAPI?CreateInstance(CComObject < Base >** ?pp)? throw ();
            };


            “普通堆對象”是使用最為頻繁的類,它有如下特征:
            (1)在堆中分配內(nèi)存 —— 計數(shù)歸零時用delete銷毀
            (2)支持獨立存在的對象 —— 使用InternalXXX來實現(xiàn)IUnknown功能
            (3)產(chǎn)生時鎖定服務(wù)器,銷毀時解鎖服務(wù)器 —— 適用于大多數(shù)COM對象

            2. CComAggObject —— 被聚合堆對象

            template? < class ?contained >
            class ?CComAggObject?:
            ????
            public ?IUnknown,
            ????
            public ?CComObjectRootEx < ?typename?contained::_ThreadModel::ThreadModelNoCS? >
            {
            public :
            ????CComAggObject(
            void * ?pv)?:?m_contained(pv)
            ????{
            ????????_pAtlModule
            -> Lock();
            ????}
            ????
            HRESULT?FinalConstruct()
            ????{
            ????????CComObjectRootEx
            < contained::_ThreadModel::ThreadModelNoCS > ::FinalConstruct();
            ????????
            return ?m_contained.FinalConstruct();
            ????}
            ????
            void ?FinalRelease()
            ????{
            ????????CComObjectRootEx
            < contained::_ThreadModel::ThreadModelNoCS > ::FinalRelease();
            ????????m_contained.FinalRelease();
            ????}
            ???
            ? virtual ? ~ CComAggObject()
            ????{
            ???????
            ?FinalRelease();
            ????????_pAtlModule -> Unlock();
            ????}

            ????STDMETHOD_(ULONG,?AddRef)()?{
            return ?InternalAddRef();}
            ????STDMETHOD_(ULONG,?Release)()
            ????{
            ????????ULONG?l?
            = ?InternalRelease();
            ????????
            if ?(l? == ? 0 )
            ????????????delete?
            this ;
            ????????
            return ?l;
            ????}
            ????STDMETHOD(QueryInterface)(REFIID?iid,?
            void ? ** ?ppvObject)
            ????{
            ????????HRESULT?hRes? = ?S_OK;
            ????????
            if ?(InlineIsEqualUnknown(iid))
            ????????{
            ????????????
            * ppvObject? = ?( void * )(IUnknown * ) this ;
            ????????????AddRef();
            ????????}
            ????????
            else
            ????????????hRes?
            = ?m_contained._InternalQueryInterface(iid,?ppvObject);
            ????????
            return ?hRes;
            ????}
            ???
            ? static ?HRESULT?WINAPI?CreateInstance(LPUNKNOWN?pUnkOuter,?CComAggObject < contained >** ?pp);

            ????CComContainedObject
            < contained > ?m_contained;
            };


            ? CComAggObject有如下特征:
            (1)在堆中分配內(nèi)存
            (2)支持被聚合聚合的對象
            ???????????實現(xiàn)了兩份IUnknown:CComAggObject實現(xiàn)了內(nèi)部聚合類真正的IUnknown,它管理對象的生存期,并且完成接口查詢(通過contained對象的_InternalQueryInterface);contained對象實現(xiàn)了具有轉(zhuǎn)發(fā)功能的IUnknown,它將所有的調(diào)用轉(zhuǎn)發(fā)給CComAggObject在構(gòu)造函數(shù)中收到的外部IUnknown指針。
            (3)產(chǎn)生時鎖定服務(wù)器,銷毀時解鎖服務(wù)器

            3. CComTearOffObject —— tear-off 對象

            template? < class ?Base >
            class ?CComTearOffObject?:? public ?Base
            {
            public :
            ????CComTearOffObject(
            void * ?pv)
            ????{
            ????????m_pOwner? = ?reinterpret_cast < Base::_OwnerClass *> (pv);
            ????????m_pOwner
            -> AddRef();
            ????}
            ???? ~ CComTearOffObject()
            ????{
            ????????FinalRelease();
            ????????m_pOwner -> Release();
            ????}

            ????STDMETHOD_(ULONG,?AddRef)()?
            throw ()?{ return ?InternalAddRef();}
            ????STDMETHOD_(ULONG,?Release)()?
            throw ()
            ????{
            ????????ULONG?l?
            = ?InternalRelease();
            ????????
            if ?(l? == ? 0 )
            ????????????delete?
            this ;
            ????????
            return ?l;
            ????}
            ????STDMETHOD(QueryInterface)(REFIID?iid,?
            void ? ** ?ppvObject)? throw ()
            ????{
            ????????
            return ?m_pOwner -> QueryInterface(iid,?ppvObject);
            ????}
            };

            ???tear-off對象有如下特征:
            (1)在堆中分配內(nèi)存
            (2)支持在ATL組件內(nèi)部使用的tear-off技術(shù)
            (3)生成時鎖定父對象,銷毀時解鎖父對象
            (4)生命周期由自己管理,接口查詢委托父對象

            4. CComObjectStack —— 棧對象
            ???
            template?<class?Base>
            class?CComObjectStackEx?:?public?Base
            {
            public:
            ????CComObjectStackEx(
            void*?=?NULL)?
            ????{?
            ????????m_hResFinalConstruct?=?FinalConstruct();?
            ????}
            ????
            virtual?~CComObjectStackEx()
            ????{
            ???????
            FinalRelease();
            ??? }

            ????STDMETHOD_(ULONG,?AddRef)()
            ????{
            ??????? return?0;
            ????}

            ????STDMETHOD_(ULONG,?Release)()
            ????{
            ????????return?0;
            ????}

            ????STDMETHOD(QueryInterface)(REFIID?iid,?
            void?**?ppvObject)
            ????{
            ????????
            return?_InternalQueryInterface(iid,?ppvObject);
            ????}

            ????HRESULT?m_hResFinalConstruct;
            };

            ???棧對象有如下特征:
            (1)內(nèi)存分配于棧上 —— 不需要對象考慮釋放問題
            (2)無引用計數(shù)功能
            (3)構(gòu)造時初始化 —— 需要在構(gòu)造函數(shù)調(diào)用后檢查m_hResFinalConstruct,以判斷對象是否構(gòu)造成功
            (4)不鎖定服務(wù)器

            5. CComObjectGlobal —— 全局對象
            template?<class?Base>
            class?CComObjectGlobal?:?public?Base
            {
            public:
            ????CComObjectGlobal(
            void*?=?NULL)
            ????{
            ???????
            m_hResFinalConstruct?=?FinalConstruct();
            ????}
            ????
            virtual?~CComObjectGlobal()
            ????{
            ?????????????FinalRelease();
            ??
            ??}
            ????STDMETHOD_(ULONG,?AddRef)()?
            throw()
            ????{
            ????????
            return?_pAtlModule->Lock();
            ????}
            ????STDMETHOD_(ULONG,?Release)()?
            throw()
            ????{
            ????????
            return?_pAtlModule->Unlock();
            ????}
            ????STDMETHOD(QueryInterface)(REFIID?iid,?
            void?**?ppvObject)?throw()
            ????{
            ????????
            return?_InternalQueryInterface(iid,?ppvObject);
            ????}
            ????HRESULT?m_hResFinalConstruct;
            };
            ???
            ???全局對象有如下特征:
            (1)在全局數(shù)據(jù)區(qū)分配內(nèi)存
            (2)初始化時不鎖定服務(wù)器,引用計數(shù)變化時才鎖定或者解鎖服務(wù)器,這使得全局對象可以被用于全局類廠對象,以解決服務(wù)器和類廠之間的死鎖問題
            (3)構(gòu)造方式同棧對象

            ???還有一些其它種類的生存期管理類,如CComObjectNoLock、CComObjectCached、CComPolyObject等等,它們也都有自己獨到的用處,我們也可以根據(jù)自己的需要編寫自定義的類。總之CComObjectRootBase、CComObjectRootEx和線程模型特征類就像是積木一樣,我們可以任意的把它們組合成想要的形狀。
            posted on 2007-04-06 15:33 michael 閱讀(3698) 評論(0)  編輯 收藏 引用 所屬分類: 心得
            久久精品国产亚洲沈樵| 人妻系列无码专区久久五月天| 伊人久久国产免费观看视频| 亚洲人成网站999久久久综合| 久久国产AVJUST麻豆| 久久w5ww成w人免费| 国产ww久久久久久久久久| 亚洲国产高清精品线久久 | 国内精品久久久久久久涩爱| 久久精品国产99久久丝袜| 亚洲AV无码成人网站久久精品大| 久久91精品国产91久久麻豆| 国产精品亚洲综合久久| 热99re久久国超精品首页| 精品久久久一二三区| 久久精品国产99久久香蕉| 精品熟女少妇a∨免费久久| 久久久久久久综合狠狠综合| 久久成人18免费网站| 精品国产一区二区三区久久| 久久国产免费直播| 亚洲伊人久久成综合人影院| 欧美亚洲国产精品久久蜜芽 | 国产99久久久国产精品小说| 97精品国产97久久久久久免费| 77777亚洲午夜久久多人| 亚洲精品国精品久久99热| 国产精品VIDEOSSEX久久发布| 久久男人Av资源网站无码软件 | 久久精品九九亚洲精品天堂| 久久精品国产亚洲AV电影| 久久99久国产麻精品66| 国内精品伊人久久久影院| 亚洲精品成人久久久| 色99久久久久高潮综合影院| 久久青青草原亚洲av无码| 久久久久久青草大香综合精品| 丁香久久婷婷国产午夜视频| 亚洲综合久久综合激情久久| 国产L精品国产亚洲区久久| 国产激情久久久久影院|