COM对象创建过程总结(进程外和进程内)

以前研究过DLL的,刚刚研究了一下EXE的情况,现在总结一下:

进程内DLL的情况下:

  1. 客户调用CoCreateInstance
  2. COM调用CoGetClassObject想获得类厂的接口指针
    1. CoGetClassObjec通过注册表找到Dll
    2. M加载该DLL到客户的进程中
    3. 调用该DLL的DllGetClassObject(CLSID, IID_IClassFactory, &ppv),返回类厂对象的IClassFactory的接口
  3. COM调用IClassFactory->CreateInstance(pUnkouter, IID, &ppvObject),创建对象,返回接口指针
  4. COM把接口指针作为结果返回

进程外EXE的情况下:

  1. 客户调用CoCreateInstance
  2. COM调用CoGetClassObject
    1. CoGetClassObject通过注册表找到EXE
    2. 启动EXE
    3. EXE在启动过程中会调用CoRegisterClassObject(CLSID, pUnk, dwClsContext, flags, &dwRegister)注册类厂对象
    4. 如果前面的对CoRegisterClassObject的调用用到了REGCLS_SUSPENDED标志,EXE调用CoResumeClassObject通知COM该对象已经做好准备接受请求(如果服务器支持多线程的话应该要这么做,避免Race Condition)
    5. CoGetClassObject取得之前CoRegisterClassObject所Register的指针(经过Marshal的)
  3. 获得了类厂对象的接口指针之后,下面的操作和进程内DLL的情况类似

  

展开阅读全文

没有更多推荐了,返回首页