青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-6  評論-0  文章-16  trackbacks-0
  2007年4月30日

COM對象實現(xiàn)接口的方法是多種多樣的,常用的有多重繼承、聚合、tear-off等。為了最大限度地支持接口查詢的多樣性,ATL使用表驅(qū)動的方式來管理接口查詢,以做到代碼封閉和擴展靈活,表條目格式為:

struct ?_ATL_INTMAP_ENTRY
{
????
const ?IID * ?piid;?
????DWORD_PTR?dw;
????_ATL_CREATORARGFUNC
* ?pFunc;?
};


piid是接口ID,dw為自定義參數(shù),pFunc是自定義函數(shù)的地址。在QueryInterface時,ATL調(diào)用pFunc,并將dw傳給pFunc,pFunc可以根據(jù)自己的需要解析dw,獲得查詢必需的信息。ATL預(yù)提供了一些函數(shù)來處理上述常用的查詢請求,如_Creator、_Delegate等,它們被放置于CComObjectRootBase中。

(1)多重繼承
???????????ATL并沒有提供支持多重繼承的函數(shù),而是將pFunc設(shè)置為_ATL_SIMPLEMAPENTRY宏,將dw設(shè)為父類子對象在子類對象中的偏移量,當(dāng)搜索表時發(fā)現(xiàn)pFunc為_ATL_SIMPLEMAPENTRY時,便直接使用偏移量相加獲得結(jié)果。

????????????if ?(pEntries -> pFunc? == ?_ATL_SIMPLEMAPENTRY)?
????????????{
????????????????IUnknown * ?pUnk? = ?(IUnknown * )((INT_PTR)pThis + pEntries -> dw);
????????????????pUnk
-> AddRef();
????????????????
* ppvObject? = ?pUnk;
????????????????
return ?S_OK;
????????????}

?????????接口映射表項宏為:

?????????#define ?COM_INTERFACE_ENTRY(x)\
?????????????{
& _ATL_IIDOF(x),?\
?????????????offsetofclass(x,?_ComMapClass),?\
?????????????_ATL_SIMPLEMAPENTRY},


(2)聚合
???????????ATL使用_Delegate函數(shù)來支持聚合,此時dw存儲的是內(nèi)部對象指針成員變量在外部對象中的偏移量,_Delegate利用此偏移量獲得內(nèi)部對象指針,然后將查詢調(diào)用委托給它。

????static ?HRESULT?WINAPI?_Delegate( void * ?pv,?REFIID?iid,? void ** ?ppvObject,?DWORD_PTR?dw)
????{
????????HRESULT?hRes?
= ?E_NOINTERFACE;
????????IUnknown
* ?p? = ? * (IUnknown ** )((DWORD_PTR)pv? + ?dw);
????????
if ?(p? != ?NULL)
????????????hRes?
= ?p -> QueryInterface(iid,?ppvObject);
????????
return ?hRes;
????}
???
?????????接口映射表項宏為:

??????#define?COM_INTERFACE_ENTRY_AGGREGATE(iid,?punk)\
??????????{
&iid,\
??????????(DWORD_PTR)offsetof(_ComMapClass,?punk),\
??????????_Delegate},
???
(3)tear-off
???????????ATL使用_Creator函數(shù)來支持tear-off,此時dw中存儲的是一個靜態(tài)_ATL_CREATORDATA結(jié)構(gòu)的地址,_Creator利用其中的指向創(chuàng)建函數(shù)的指針創(chuàng)建一個tear-off對象。
??????????????????
?????????static?HRESULT?WINAPI?_Creator(void*?pv,?REFIID?iid,?void**?ppvObject,?DWORD_PTR?dw)
?????????{
??????????????_ATL_CREATORDATA
*?pcd?=?(_ATL_CREATORDATA*)dw;
??????????????
return?pcd->pFunc(pv,?iid,?ppvObject);
?????????}

?????????接口映射表項宏為:
????????????
??????#define?COM_INTERFACE_ENTRY_TEAR_OFF(iid,?x)\
??????????{
&iid,\
??????????(DWORD_PTR)
&ATL::_CComCreatorData<\
??????????????ATL::CComInternalCreator
<?ATL::CComTearOffObject<?x?>?>\
??????????????
>::data,\
??????????_Creator},

??????_ComCreatorData的相關(guān)定義如下:
??????
struct?_ATL_CREATORDATA
{
????_ATL_CREATORFUNC
*?pFunc;
};

template?
<class?Creator>
class?_CComCreatorData
{
public:
????
static?_ATL_CREATORDATA?data;
};

template?
<class?Creator>
_ATL_CREATORDATA?_CComCreatorData
<Creator>::data?=?{Creator::CreateInstance};


??????我們還可以定義自己的接口查詢輔助函數(shù)和輔助數(shù)據(jù),通過dw和pFunc來完成各種千奇百怪的接口實現(xiàn)方式,需要的只是想象力。
posted @ 2007-04-30 11:37 michael 閱讀(709) | 評論 (0)編輯 收藏
  2007年4月10日
?????????在COM中對象要通過class factory的接口(通常是IClassFactory)來創(chuàng)建。在ATL中,class factory也是從CComObjectRootEx派生的COM類,它跟普通的COM類一樣,也通過CComObject或其同伴類將邏輯功能跟生存期管理分離。
?????????在ATL中,class factory類和普通類對象的創(chuàng)建都可以通過被稱為“創(chuàng)建者”的模板類來創(chuàng)建。
?????????
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;
????}
};

?????????“創(chuàng)建者”通過提供一個靜態(tài)函數(shù)CreateInstance來創(chuàng)建指定類的實例,并且查詢指定的接口。第一個參數(shù)在實例化普通對象和class factory對象時會有不同:對于普通對象,通常會傳遞聚合外部對象的IUnknown指針,如果是非聚合創(chuàng)建,可以傳遞NULL(詳見ATL對COM實體身份的支持四);稍后會介紹在class factory創(chuàng)建時第一個參數(shù)的用處。
?????????在ATL中,一個class factory對象只能創(chuàng)建一種類型的COM類實例。在class factory的CreateInstance函數(shù)中,它不是硬編碼被創(chuàng)建的對象類型,而是通過一個函數(shù)指針成員變量來創(chuàng)建它所管理的對象,而這個函數(shù)指針指向的通常就是某個COM類的“創(chuàng)建者”類的CreateInstance靜態(tài)函數(shù)的地址,此地址是在class factory對象被它自身的“創(chuàng)建者”的CreateInstance函數(shù)創(chuàng)建時通過第一個參數(shù)傳進來的,class factory重新定義了SetVoid函數(shù),并且保存這個地址:
?????????
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;
};

?????????根據(jù)上面的討論,一個COM類的創(chuàng)建者會像這個樣子:
?????????CComCreator<?CComObject<CMyClass> >
?????????而一個class factory的創(chuàng)建者會像這個樣子:
?????????CComCreator< CComCachedObject<CComClassFactory> >。
?????????
?????????ATL在客戶請求創(chuàng)建CMyClass對象時執(zhí)行的偽代碼如下:
?????????
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 @ 2007-04-10 17:36 michael 閱讀(1559) | 評論 (0)編輯 收藏
  2007年4月6日

??????有了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)在全局?jǐn)?shù)據(jù)區(qū)分配內(nèi)存
(2)初始化時不鎖定服務(wù)器,引用計數(shù)變化時才鎖定或者解鎖服務(wù)器,這使得全局對象可以被用于全局類廠對象,以解決服務(wù)器和類廠之間的死鎖問題
(3)構(gòu)造方式同棧對象

???還有一些其它種類的生存期管理類,如CComObjectNoLock、CComObjectCached、CComPolyObject等等,它們也都有自己獨到的用處,我們也可以根據(jù)自己的需要編寫自定義的類??傊瓹ComObjectRootBase、CComObjectRootEx和線程模型特征類就像是積木一樣,我們可以任意的把它們組合成想要的形狀。
posted @ 2007-04-06 15:33 michael 閱讀(3715) | 評論 (0)編輯 收藏
1.CComSingleThreadModel和CComMultiThreadModel特征類:
class?CComSingleThreadModel
{
public:
????
static?ULONG?WINAPI?Increment(LPLONG?p)?throw()?{return?++(*p);}
????
static?ULONG?WINAPI?Decrement(LPLONG?p)?throw()?{return?--(*p);}
????typedef?CComFakeCriticalSection?AutoCriticalSection;
????typedef?CComFakeCriticalSection?CriticalSection;
????typedef?CComSingleThreadModel?ThreadModelNoCS;
};
class?CComMultiThreadModel
{
public:
????
static?ULONG?WINAPI?Increment(LPLONG?p)?throw()?{return?InterlockedIncrement(p);}
????
static?ULONG?WINAPI?Decrement(LPLONG?p)?throw()?{return?InterlockedDecrement(p);}
????typedef?CComAutoCriticalSection?AutoCriticalSection;
????typedef?CComCriticalSection?CriticalSection;
????typedef?CComMultiThreadModelNoCS?ThreadModelNoCS;
};
其中的CFakeCriticalSection定義如下:
class?CComFakeCriticalSection
{
public:
????HRESULT?Lock()?
throw()?{?return?S_OK;?}
????HRESULT?Unlock()?
throw()?{?return?S_OK;?}
????HRESULT?Init()?
throw()?{?return?S_OK;?}
????HRESULT?Term()?
throw()?{?return?S_OK;?}
};

這兩個類提供了針對特定套間對象的同步控制支持。
CComSingleThreadModel適用于單線程套間對象,它不采用任何線程同步機制;CComMultiThreadModel適用于多線程套間對象,它使用win32的同步機制來實現(xiàn)。

2.CComObjectRootEx模板類
template?<class?ThreadModel>
class?CComObjectRootEx?:?public?CComObjectRootBase
{
public:
????typedef?ThreadModel?_ThreadModel;
????typedef?typename?_ThreadModel::AutoCriticalSection?_CritSec;
????typedef?CComObjectLockT
<_ThreadModel>?ObjectLock;

????ULONG?InternalAddRef()
????{
???????
?return?_ThreadModel::Increment(&m_dwRef);
????}
????ULONG?InternalRelease()
????{
????????return?_ThreadModel::Decrement(&m_dwRef);
????}

????
void?Lock()?{m_critsec.Lock();}
????
void?Unlock()?{m_critsec.Unlock();}

private:
????_CritSec?m_critsec;
};

它使用傳入的線程模型特征類來實現(xiàn)對象獨立存在時所需要的引用計數(shù)支持,同時提供了一個方便對象開發(fā)使用的同步鎖,我們可以使用這個鎖來完成對自定義數(shù)據(jù)訪問的保護。
posted @ 2007-04-06 14:39 michael 閱讀(1638) | 評論 (0)編輯 收藏

下面是CComObjectRootBase的關(guān)鍵代碼:

class ?CComObjectRootBase
{
public :
?????// 構(gòu)造支持
?????//
??
???HRESULT?FinalConstruct();
???? void?FinalRelease();?

?????//??接口查詢支持
?????//
?????static?HRESULT?WINAPI?InternalQueryInterface(void*?pThis,
????????
const?_ATL_INTMAP_ENTRY*?pEntries,?REFIID?iid,?void**?ppvObject);
???
????static?HRESULT?WINAPI?_Break(void*,?REFIID?iid,?void**??,?DWORD_PTR?);
????static?HRESULT?WINAPI?_NoInterface(void*??,?REFIID?,?void**??,?DWORD_PTR?);
????static?HRESULT?WINAPI?_Creator(void*?pv,?REFIID?iid,?void**ppvObject,?DWORD_PTR?dw);
????static?HRESULT?WINAPI?_Delegate(void*?pv,?REFIID?iid,?void**?ppvObject,?DWORD_PTR?dw);
???
?static?HRESULT?WINAPI?_Chain(void*?pv,?REFIID?iid,?void**?ppvObject,?DWORD_PTR?dw);
???
static?HRESULT?WINAPI?_ChainAttr(void*?pv,?REFIID?iid,?void**?ppvObject,?DWORD_PTR?dw);
???
?static?HRESULT?WINAPI?_Cache(void*?pv,?REFIID?iid,?void**?ppvObject,?DWORD_PTR?dw);

????//? 聚合支持
??? //
?
???ULONG?OuterAddRef()
????{
????????
return?m_pOuterUnknown->AddRef();
????}
????ULONG?OuterRelease()
????{
????????
return?m_pOuterUnknown->Release();
????}
????HRESULT?OuterQueryInterface(REFIID?iid,?
void?**?ppvObject)
????{
????????
return?m_pOuterUnknown->QueryInterface(iid,?ppvObject);
????}
????
??? //?實體身份支持
??? //
????union
????{
????????
long?m_dwRef;
???????? IUnknown
*?m_pOuterUnknown;
????};
};

CComObjectRootBase主要功能分為:
(1)構(gòu)造支持:
????????????即FinalConstruct和FinalRelease,它們用于安全的構(gòu)造和銷毀對象。
(2)接口查詢支持
????????????通過接口映射表來完成接口查詢功能,詳細內(nèi)容見后面的文章。
(3)聚合狀態(tài)下引用計數(shù)操作的支持
????????????提供了將IUnknown請求委托給外部組件的支持。當(dāng)對象獨立存在時,對引用計數(shù)操作的支持被放置于CComObjectRootEx中,因為涉及到了套間和訪問同步。
(4)實體身份支持
????????????使得對象可以獨立存在或者被聚合,因為運行時刻對象只能以一種方式存在,所以使用了union。
posted @ 2007-04-06 13:51 michael 閱讀(1544) | 評論 (0)編輯 收藏
ATLComClasses.JPG
????????????一個COM對象必須實現(xiàn)IUnknown接口所規(guī)定的功能,即生命期管理和運行時類型轉(zhuǎn)換。
(1)基本IUnknow功能
??????????? 對象的生存方式可以是堆存儲、棧存儲以及全局存儲,同時COM還提供了一種被聚合的生存方式。生存方式不同,AddRef、Release和QueryInterface的實現(xiàn)方式就不同。比如:對于堆方式,Release要在引用計數(shù)歸零時負(fù)責(zé)釋放堆空間,而棧以及全局方式則不必;對于聚合方式,AddRef、Release以及大部分的QueryInterface調(diào)用要委托給外部對象。
??????????? 為了達到對象的邏輯功能與其生存方式的分離,COM把對IUnknown基本功能的實現(xiàn)推遲到類層次結(jié)構(gòu)的最底層,即CComObject(或它的其他伙伴)處。
??????????? CComObjectRootBase為CComObject的實現(xiàn)提供原材料的支持,如提供引用計數(shù)變量、基本的接口查詢機制等,它是一個“功能集中類”。
(2)套間安全支持
??????????? 根據(jù)對象所處的套間類型,對象功能的實現(xiàn)需要不同的同步支持。對于單線程套間對象,由COM庫來保證訪問的同步;而對于多線程套間對象,需要自己來同步調(diào)用。為了使套間安全支持與邏輯功能分離,ATL提供了一組提供線程安全操作支持的特征類(traits類)—— CComSingleThreadModel及其伙伴。它們提供了對一個LONG變量“恰好線程安全”的增減操作,以及跟套間類型匹配的CriticalSection功能類。
??????????? ATL同時提供了CComObjectRootEx模板類,它以某種ThreadModel特征類作為參數(shù),提供對引用計數(shù)“恰好線程安全”的操作,并且提供了一個用于對象同步的鎖。
????????????PS:“恰好線程安全”的操作的意思是:對于需要線程同步的對象,提供win32 CriticalSection支持;對于不需要的對象,則什么也不做。
posted @ 2007-04-06 11:46 michael 閱讀(1402) | 評論 (0)編輯 收藏
僅列出標(biāo)題  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            午夜在线成人av| 怡红院精品视频| 亚洲资源av| 一区二区三区日韩欧美精品| 欧美激情在线免费观看| 亚洲高清不卡在线观看| 亚洲国产日韩欧美在线99| 亚洲精品一区二区三区婷婷月| 亚洲精品网站在线播放gif| 宅男在线国产精品| 午夜久久黄色| 久久久国产精品一区二区三区| 久久一区二区三区四区五区| 欧美经典一区二区| 国产精品视区| 怡红院精品视频在线观看极品| 亚洲国产你懂的| 亚洲一级黄色片| 久久网站免费| 99热这里只有精品8| 欧美一区二区精品| 欧美久久久久久| 国产亚洲视频在线观看| 日韩视频中午一区| 久久精品国产视频| 日韩视频精品在线| 久久久久国产精品午夜一区| 欧美交受高潮1| 国产色产综合产在线视频| 亚洲人www| 久久午夜精品| 亚洲校园激情| 欧美乱妇高清无乱码| 国内精品久久久久伊人av| 亚洲影视在线播放| 亚洲国产天堂网精品网站| 久久国内精品视频| 国产精品久久久久永久免费观看| 91久久久亚洲精品| 久久人人97超碰国产公开结果 | 亚洲国产日韩一级| 亚洲一区二区三区在线播放| 久久综合影音| 国产一区二区三区黄视频| 亚洲影院色无极综合| 亚洲二区在线| 久久久亚洲综合| 国际精品欧美精品| 欧美在线视频观看| 亚洲一区二区成人在线观看| 欧美区在线播放| 最新国产成人在线观看| 久久夜色精品国产| 欧美一区二区三区四区夜夜大片| 国产精品日韩欧美| 亚洲综合欧美| 亚洲一级在线观看| 欧美日韩综合在线| 亚洲永久免费精品| 亚洲一区二区在线免费观看视频| 国产精品久久久久久久久久尿 | 欧美黄色aaaa| 91久久久在线| 亚洲欧洲精品一区二区精品久久久| 狂野欧美激情性xxxx| 亚洲第一天堂av| 欧美激情一区二区三区在线 | 亚洲自拍偷拍视频| 国产精品欧美久久久久无广告| 亚洲午夜国产一区99re久久| 一区二区久久久久久| 国产精品黄视频| 久久成人一区二区| 久久理论片午夜琪琪电影网| 亚洲国产精品传媒在线观看| 亚洲风情亚aⅴ在线发布| 欧美极品在线播放| 亚洲欧美国产精品专区久久| 小处雏高清一区二区三区| 在线不卡视频| 欧美激情精品久久久久久黑人| 欧美成人精品一区二区三区| 亚洲淫性视频| 久久综合九色九九| 亚洲一区二区三区四区在线观看| 午夜精品福利一区二区三区av| 激情久久久久久久| 亚洲精品美女91| 国产一本一道久久香蕉| 亚洲国产成人久久| 国产九九视频一区二区三区| 欧美国产免费| 免费观看一级特黄欧美大片| 欧美成人有码| 国产精品高潮呻吟久久av黑人| 欧美影院精品一区| 欧美a级片一区| 欧美中文字幕在线观看| 欧美www视频| 久久九九国产精品怡红院| 欧美激情第1页| 久久久噜噜噜| 国产精品高清免费在线观看| 国产精品一香蕉国产线看观看| 亚洲精品综合| 欧美aaaaaaaa牛牛影院| 欧美 日韩 国产精品免费观看| 国产在线观看91精品一区| 亚洲国产精品免费| 国产亚洲福利社区一区| 亚洲激情欧美激情| 狠狠色丁香婷综合久久| 中国亚洲黄色| 99re亚洲国产精品| 久久久中精品2020中文| 久久国产精品久久久| 欧美日韩精品免费在线观看视频| 美女诱惑一区| 国产专区综合网| 亚洲欧美国产日韩天堂区| 亚洲视频精选| 欧美精品国产精品| 欧美激情第六页| 在线观看欧美亚洲| 久久精品国产欧美亚洲人人爽| 午夜视频久久久| 欧美视频导航| 99日韩精品| 亚洲图片欧美日产| 欧美日韩一级视频| 亚洲最新在线| 亚洲欧美国产三级| 国产精品免费一区豆花| 亚洲天堂视频在线观看| 小处雏高清一区二区三区| 性欧美1819性猛交| 欧美日韩精品系列| 日韩午夜一区| 国产在线视频欧美| 欧美在线播放| 久久久久久久一区二区| 狠狠色狠狠色综合日日五| 久久精品99无色码中文字幕| 久久综合久久综合久久| 亚洲国产成人av| 欧美精品成人一区二区在线观看 | 亚洲一区综合| 国产免费成人| 久久久久久免费| 亚洲国产精品久久91精品| 一区二区三区av| 一区二区高清| 欧美在线观看一二区| 欧美日韩国产不卡| 国产精品99久久久久久久vr| 欧美一区二区高清在线观看| 国产精品一区二区三区乱码 | 久久久久久久久久久久久女国产乱 | 亚洲自拍偷拍视频| 国产精品羞羞答答| 久久黄金**| 亚洲精品午夜精品| 欧美一区成人| 亚洲国产天堂久久国产91| 欧美日韩国产精品一卡| 性欧美暴力猛交69hd| 欧美国产成人精品| 午夜精品久久久久久久久久久久久| 国语自产精品视频在线看| 久久精品欧美日韩精品| 亚洲毛片视频| 久久最新视频| 亚洲一区欧美激情| 亚洲电影av在线| 国产精品一区二区三区成人| 蜜臀va亚洲va欧美va天堂| 亚洲一区二区高清| 亚洲国产日韩欧美在线图片| 久久精品网址| 亚洲一级影院| 亚洲乱码国产乱码精品精98午夜 | 亚洲韩国一区二区三区| 国产精品成人在线观看| 欧美在线视频导航| 亚洲作爱视频| 亚洲人体一区| 老巨人导航500精品| 午夜电影亚洲| 中文在线资源观看视频网站免费不卡| 韩国成人精品a∨在线观看| 国产精品videosex极品| 麻豆视频一区二区| 欧美主播一区二区三区美女 久久精品人| 亚洲国产欧美另类丝袜| 蜜臀91精品一区二区三区| 西西裸体人体做爰大胆久久久| 99在线精品视频在线观看| 亚洲黄色在线| 亚洲人成人77777线观看| 激情欧美日韩一区|