以前研究过DLL的,刚刚研究了一下EXE的情况,现在总结一下:
进程内DLL的情况下:
- 客户调用CoCreateInstance
- COM调用CoGetClassObject想获得类厂的接口指针
- CoGetClassObjec通过注册表找到Dll
- M加载该DLL到客户的进程中
- 调用该DLL的DllGetClassObject(CLSID, IID_IClassFactory, &ppv),返回类厂对象的IClassFactory的接口
- COM调用IClassFactory->CreateInstance(pUnkouter, IID, &ppvObject),创建对象,返回接口指针
- COM把接口指针作为结果返回
进程外EXE的情况下:
- 客户调用CoCreateInstance
- COM调用CoGetClassObject
- CoGetClassObject通过注册表找到EXE
- 启动EXE
- EXE在启动过程中会调用CoRegisterClassObject(CLSID, pUnk, dwClsContext, flags, &dwRegister)注册类厂对象
- 如果前面的对CoRegisterClassObject的调用用到了REGCLS_SUSPENDED标志,EXE调用CoResumeClassObject通知COM该对象已经做好准备接受请求(如果服务器支持多线程的话应该要这么做,避免Race Condition)
- CoGetClassObject取得之前CoRegisterClassObject所Register的指针(经过Marshal的)
- 获得了类厂对象的接口指针之后,下面的操作和进程内DLL的情况类似
本文详细介绍了在进程内DLL和进程外EXE两种情况下,通过COM接口如何创建组件的具体流程。对于进程内DLL,文章解释了从客户调用CoCreateInstance开始,到COM获取类厂对象并创建实例的整个过程。对于进程外EXE,则涵盖了从启动EXE到完成对象注册,再到最终创建实例的步骤。

被折叠的 条评论
为什么被折叠?



