• <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
            ?????????在COM中對象要通過class factory的接口(通常是IClassFactory)來創建。在ATL中,class factory也是從CComObjectRootEx派生的COM類,它跟普通的COM類一樣,也通過CComObject或其同伴類將邏輯功能跟生存期管理分離。
            ?????????在ATL中,class factory類和普通類對象的創建都可以通過被稱為“創建者”的模板類來創建。
            ?????????
            template?<class?T1>
            class?CComCreator
            {
            public:
            ????
            static?HRESULT?WINAPI?CreateInstance(void*?pv,?REFIID?riid,?LPVOID*?ppv)
            ????{
            ????????HRESULT?hRes?=?E_OUTOFMEMORY;
            ????????T1
            *?p?=?NULL;
            ????????p?
            =?new?T1(pv);
            ????????
            if?(p?!=?NULL)
            ????????{
            ????????????p
            ->SetVoid(pv);
            ????????????p
            ->InternalFinalConstructAddRef();
            ????????????hRes?
            =?p->FinalConstruct();
            ????????????
            p->InternalFinalConstructRelease();
            ????????????
            if?(hRes?==?S_OK)
            ????????????????hRes?
            =?p->QueryInterface(riid,?ppv);
            ????????????
            if?(hRes?!=?S_OK)
            ????????????????delete?p;
            ????????}
            ????????
            return?hRes;
            ????}
            };

            ?????????“創建者”通過提供一個靜態函數CreateInstance來創建指定類的實例,并且查詢指定的接口。第一個參數在實例化普通對象和class factory對象時會有不同:對于普通對象,通常會傳遞聚合外部對象的IUnknown指針,如果是非聚合創建,可以傳遞NULL(詳見ATL對COM實體身份的支持四);稍后會介紹在class factory創建時第一個參數的用處。
            ?????????在ATL中,一個class factory對象只能創建一種類型的COM類實例。在class factory的CreateInstance函數中,它不是硬編碼被創建的對象類型,而是通過一個函數指針成員變量來創建它所管理的對象,而這個函數指針指向的通常就是某個COM類的“創建者”類的CreateInstance靜態函數的地址,此地址是在class factory對象被它自身的“創建者”的CreateInstance函數創建時通過第一個參數傳進來的,class factory重新定義了SetVoid函數,并且保存這個地址:
            ?????????
            class?CComClassFactory?:
            ????
            public?IClassFactory,
            ????
            public?CComObjectRootEx<CComGlobalsThreadModel>
            {
            public:
            ????
            //?IClassFactory
            ????STDMETHOD(CreateInstance)(LPUNKNOWN?pUnkOuter,?REFIID?riid,?void**?ppvObj)
            ????{
            ????????HRESULT?hRes?=?E_POINTER;
            ????????
            if?(ppvObj?!=?NULL)
            ????????{
            ????????????
            *ppvObj?=?NULL;
            ????????????if?((pUnkOuter?!=?NULL)?&&?!InlineIsEqualUnknown(riid))
            ????????????{
            ????????????????hRes?=?CLASS_E_NOAGGREGATION;
            ????????????}
            ????????????
            else
            ????????????????hRes?
            =?m_pfnCreateInstance(pUnkOuter,?riid,?ppvObj);
            ????????}
            ????????
            return?hRes;
            ????}

            ????STDMETHOD(LockServer)(BOOL?fLock)
            ????{
            ????????
            if?(fLock)
            ????????????_pAtlModule
            ->Lock();
            ????????
            else
            ????????????_pAtlModule
            ->Unlock();
            ????????
            return?S_OK;
            ????}
            ?
            ????void?SetVoid(void*?pv)
            ????{
            ????????m_pfnCreateInstance?
            =?(_ATL_CREATORFUNC*)pv;
            ????}

            ????_ATL_CREATORFUNC
            *?m_pfnCreateInstance;
            };

            ?????????根據上面的討論,一個COM類的創建者會像這個樣子:
            ?????????CComCreator<?CComObject<CMyClass> >
            ?????????而一個class factory的創建者會像這個樣子:
            ?????????CComCreator< CComCachedObject<CComClassFactory> >。
            ?????????
            ?????????ATL在客戶請求創建CMyClass對象時執行的偽代碼如下:
            ?????????
            typedef?CComCreator<?CComCachedObject<CComClassFactory>?>?CClassFactoryCreator;
            typedef?CComCreator
            <?CComObject<CMyClass>?>?CMyClassCreator;

            IClassFactory
            *?pcf=NULL;
            CClassFactoryCreator::CreateInstance(
            &CMyClassCreator::CreateInstance,__uuidof(IClassFactory),&pcf);
            pcf
            ->CreateInstance(pOuter,__uuidof(IMyInterface),ppvObj);
            posted on 2007-04-10 17:36 michael 閱讀(1545) 評論(0)  編輯 收藏 引用 所屬分類: 心得
            无码任你躁久久久久久老妇| 97超级碰碰碰久久久久| 亚洲国产成人久久精品动漫| 久久精品国产亚洲av影院| 97精品依人久久久大香线蕉97| 亚洲欧美另类日本久久国产真实乱对白| 国产精品久久久久影视不卡| 久久精品国产免费观看三人同眠| 欧美一级久久久久久久大片| 久久国产香蕉一区精品| 久久综合九色综合久99| 久久精品视频一| 99久久国产精品免费一区二区| 久久99精品久久久大学生| 亚洲综合伊人久久大杳蕉| 久久精品无码专区免费东京热| 国产韩国精品一区二区三区久久| 久久免费视频观看| 久久国产精品免费| 国产激情久久久久久熟女老人| 久久99热这里只有精品国产| 精品久久8x国产免费观看| 99久久99久久精品国产| 国内精品伊人久久久影院| 久久国产精品99国产精| 国产精品xxxx国产喷水亚洲国产精品无码久久一区| 欧美777精品久久久久网| 久久亚洲电影| 97精品久久天干天天天按摩| 久久男人AV资源网站| 国内精品久久久久久99| 久久最新免费视频| 久久精品www人人爽人人| 久久久人妻精品无码一区| 日本人妻丰满熟妇久久久久久| 亚洲综合精品香蕉久久网97| 久久午夜无码鲁丝片秋霞| 久久午夜电影网| 色欲久久久天天天综合网| 久久久久久噜噜精品免费直播 | 久久精品成人一区二区三区|