轉(zhuǎn)載自:網(wǎng)絡(luò),來源未知,如有知曉者請告知我。
需求:
1.創(chuàng)建myCom.dll,該COM只有一個組件,兩個接口:
IGetRes--方法Hello(),
IGetResEx--方法HelloEx()
2.在工程中導(dǎo)入組件或類型庫
#import "組件所在目錄myCom.dll" no_namespace
或
#import "類型庫所在目錄myCom.tlb"
using namespace MYCOM;
方法一:
CoInitialize(NULL);
CLSID clsid;
CLSIDFromProgID(OLESTR("myCom.GetRes"),&clsid);
CComPtr<IGetRes> pGetRes;//智能指針
pGetRes.CoCreateInstance(clsid);
pGetRes->Hello();
pGetRes.Release();//小心哦!!請看最后的“注意”
CoUninitialize();
方法二:
CoInitialize(NULL);
CLSID clsid;
HRESULT hr=CLSIDFromProgID(OLESTR("myCom.GetRes"),&clsid);
IGetRes *ptr;
hr=CoCreateInstance(clsid,NULL,CLSCTX_INPROC_SERVER,
__uuidof(IGetRes),(LPVOID*)&ptr);
ptr->Hello();
CoUninitialize();
方法三:
CoInitialize(NULL);
HRESULT hr;
CLSID clsid;
hr=CLSIDFromProgID(OLESTR("myCom.GetRes"),&clsid);
IGetRes* ptr;
IGetResEx* ptrEx;
//使用CoCreateClassObject創(chuàng)建一個組件(特別是mutilThreads)的多個對象的
時候,效率更高.
IClassFactory* p_classfactory;
hr=CoGetClassObject(clsid,CLSCTX_INPROC_SERVER,
NULL,IID_IClassFactory,
(LPVOID*)&p_classfactory);
p_classfactory->CreateInstance(NULL,__uuidof(IGetRes),
(LPVOID*)&ptr);
p_classfactory->CreateInstance(NULL,__uuidof(IGetResEx),
(LPVOID*)&ptrEx);
ptr->Hello();
ptrEx->HelloEx();
CoUninitialize();

方法四:
直接從dll中得到DllGetClassObject,接著生成類對象及類實例(這方法可以
使組件不用在注冊表里注冊,這是最原始的方法,但這樣做沒什么意義,至少失去了COM
對用戶的透明性),不推薦使用.
typedef HRESULT (__stdcall * pfnHello)(REFCLSID,REFIID,void**);
pfnHello fnHello= NULL;
HINSTANCE hdllInst = LoadLibrary("組件所在目錄myCom.dll");
fnHello=(pfnHello)GetProcAddress(hdllInst,"DllGetClassObject");
if (fnHello != 0)

{
IClassFactory* pcf = NULL;
HRESULT hr=(fnHello)(CLSID_GetRes,IID_IClassFactory,(void**)&pcf);
if (SUCCEEDED(hr) && (pcf != NULL))

{
IGetRes* pGetRes = NULL;
hr = pcf->CreateInstance(NULL, IID_IFoo, (void**)&pGetRes);
if (SUCCEEDED(hr) && (pFoo != NULL))

{
pGetRes->Hello();
pGetRes->Release();
}
pcf->Release();
}
}
FreeLibrary(hdllInst);

方法五:
通過ClassWizard利用類型庫生成包裝類,不過前提是com組件的接口必須是派
生自IDispatch,具體方法:
調(diào)出添加類向?qū)?span lang="EN-US">(.NET中),選擇類型庫中MFC類,打開,選擇"文件",選擇
"myCom.dll"或"myCom.tlb",接下來會出來該myCom中的所有接口,選擇你想
生成的接口包裝類后,向?qū)詣由上鄳?yīng)的.h文件.這樣你就可以在你的MFC中
像使用普通類那樣使用組件了.(CreateDispatch("myCom.GetRes") 中的參數(shù)就是ProgID通過Clsid在注冊表中可以查詢的到)
CoInitialize(NULL);
CGetRes getRest;
if (getRest.CreateDispatch("myCom.GetRes") != 0)

{
getRest.Hello();
getRest.ReleaseDispatch();
}
CoUninitialize();

注意:
COM中的智能指針實際上是重載了->的類,目的是為了簡化引用記數(shù),幾不需要程序
員顯示的調(diào)用AddRef()和Release(),但是為什么我們在Method 1中
pGetRes.Release(),問題在與,我們的智能指針pGetRes生命周期的結(jié)束是在
CoUninitialize()之后,CoInitialize所開的套間在CoUninitialize()后已經(jīng)被
關(guān)閉,而pGetRes此時發(fā)生析構(gòu),導(dǎo)致了程序的崩潰,解決這個問題的另一個方法是
CoInitialize(NULL);
CLSID clsid;
CLSIDFromProgID(OLESTR("myCom.GetRes"),&clsid);

{
CComPtr<IGetRes> pGetRes;//智能指針
pGetRes.CoCreateInstance(clsid);
pGetRes->Hello();
}
CoUninitialize();

以上就是COM的5中方法,當(dāng)然具體怎么使用還是在于程序的環(huán)境,加以琢磨....