COM第四部分(高级特性:重用性、跨进程性、多线程模型)

面向对象思想在COM组件中的体现;
1.封装:用户如果想访问对象内部属性,必须通过对象暴漏在外的接口;
2.多态:体现在成员函数、单个接口和一组接口三个层次上;
3.继承:COM重用性是建立在二进制一级。具体包括包容和聚合两种重用模型。

高级特性一:包容和聚合
包容和聚合都是COM组件体现重用性的两种形式;
1.包容:
外部组件程序包含内部组件程序,客户通过外部组件的接口间接的使用内部组件程序的功能;
客户也无法感知到内部组件的存在,也无法知道内部组件有什么接口;
在这里插入图片描述

包容如上图。
客户无法感知对象B的存在,也不知道B的接口,只能去访问A的接口IA,通过IA访问IB提供服务。

2.聚合:
实际上聚合时包容的一种特殊形式
客户访问内部组件没有经过外部组件的转发,而是客户可以直接访问内部组件的接口。
但是客户仅仅时通过接口访问内部组件,同样无法感知到内部组件的存在
在这里插入图片描述

聚合如上图:客户可以直接拿到内部组件的接口直接使用,而不再经过外部组件去调用该接口。由IA将IB的接口暴漏给客户使用

问题1:
从客户的角度看,对于包容、内聚两种形式,用户知道内部组件的存在吗?
答:
不知道。对于包容来讲,用户是通过外部组件接口间接调用内部组件的
对于聚合来讲,虽然用户可以直接访问到内部的接口,但是外部将内部隐藏了起来,客户只能知道接口来自外部组件,而不知道真正来自于内部。

问题2:
COM的重用模型有包容和内聚,什么时候用包容,什么时候用内聚?
答:
包容:当A组件对象给客户提供服务时,B组件中的功能可以被A使用,A就可以将B包含在自己的内部,由A调用B的接口
聚合:当A组件给客户提供服务时,B在A的内部,当客户请求接口时,刚好B有这个功能,A就把B的接口直接暴漏给客户使用。
问题3:
COM对象的重用性体现的是源代码的重用还是二进制的重用?
答:
二进制。COM组件的本身就是建立在二进制的基础上,解决跨平台、跨语言等障碍。

高级特性二:COM的跨进程性
组件服务程序种类的划分:
1.组件内服务程序:
一般以DLL动态库的形式存在,运行时动态的加载在客户程序中。
2.本地服务程序:
一般以EXE可执行文件的形式存在,和客户的程序处于不同的虚拟地址空间。
3.远程服务程序:
可以是EXE也可以是DLL,和客户程序处于不同的主机。

一般我们将2和3统称为进程外组件:
问题1:进程外通信和进程内通信各自的优缺点是什么?
答:
进程内通信运行速度快,加载到内存即可调用,但是如DLL崩溃,会导致客户程序的崩溃;
进程间通信速度较慢,因为要先建立连接,但是是独立的地址空间,组件崩溃不会影响客户程序崩溃,稳定性高。
问题2:进程外通信方式是什么?
答:
RPC.
在这里插入图片描述
简单建立通信过程如上图。
通讯过程中的几个中要概念:
1.列集:指客户程序透明的调用另一个进程中对象成员函数的一种参数机制,可以理解为将客户的参数“打包”起来,通过ORPC将列集送给组件程序
分为标准列集和自定义列集
2.存根:存根中保存着对象的方法接口,它负责将ORPC中的列集散集出来,并准确的将参数传给对象接口。

在这里插入图片描述
标准列集的通讯机制如图:
标准列集通讯的基本流程如下:
1.客户通过列集的手段将参数统一起来,通过代理对象调用系统的RPC通信机制;
2.系统RPC通信机制将参数数据通过网络传递给目标主机的RPC系统;
3.目标主机的RPC系统将传给存根对象,存根对象对列集数据进程散列,准确的将参数传递给对象方法。

高级特性三:多线程模型
WIN32的线程分为两种:
1.UI线程:一种与一个窗口绑定的线程
2.工作线程:一般一个线程对于这一个函数。
COM提供的线程模型:
1.STA单线程模型
2.MTA多线程模型
3.NA/TNA/NTA中立线程套间。

#########################################################
本文中的重点在与特性1和特性2:

聚合模型:
在这里插入图片描述
在聚合的情况下,当客户通过内部接口请求内部COM对象所不支持的接口或Iunkown接口时,内部对象必须把控制权交给外部对象。

包容模型:
在这里插入图片描述

聚合 客户能看到的:只有外部接口
在这里插入图片描述

聚合:支持聚合的对象在聚合方式下的接口示意图
在这里插入图片描述
内存结构:
在这里插入图片描述

创建内部对象的调用堆栈以及指针的传递过程
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值