博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
COM编程--学习笔记
阅读量:6574 次
发布时间:2019-06-24

本文共 1374 字,大约阅读时间需要 4 分钟。

C++与COM 对象通信方法
1、调用COM DLL时COM不需要做什么特别的工作;
2、但是调用COM EXE服务器上的方法时,在实际过程中程序并不是马上进入被调用的函数,而先执行一个“代理”的中间函数:代理函数将调用的参数序列化为标准的COM客户/服务器协议的格式,然后放到连向COM EXE的信道中;在信道的另一端是一个叫做“桩子”的函数,“桩子”函数将参数包解开,真正实现对所请求方法的调用;总之,COM为你做了以前你必须自己完成的通信工作,对于有返回值的方法,桩子和代理交换一下动作。
3、代理和桩子函数的产生:由COM自动完成,当CoCreateInstance()创建对象时,不仅启动了相应的EXE,而且返回了对象的指针,返回的指针给代理函数;因此,根据你所创建的对象的类型不同,你或者得到真实对象的指针,或者得到指向代理函数的指针。
4、代理函数从何而来?实际上来自一个代理/桩子DLL;CoCreateInstance()查看系统注册表中的Interface()键将接口ID映射到DLL文件名,从而找到所需要的DLL文件,然后在你的“应用程序”和“COM EXE服务器端”都装入这个DLL。COM根据接口ID请求EXE所建所需要的类的对象;
COM将同一个接口ID映射到系统注册表中的代理/桩子DLL文件;
COM调用LoadLibrary()在客户和EXE服务器两端都装载同一个DLL;
代理/桩子DLL用于在网络通信的过程中打包和解开参数;
5、不要在应用程序之间交换内存指针: 进程空间 在程序中出现的数据指针(char *p),指向的其实不是内存中真正的物理地址,而是应用程序换入内存时CPU指定给程序的逻辑地址。因为如果CPU给你的程序指定的是物理地址,那么当程序在内存中换入换出来说可能毫无意义,在应用程序之间传递数据时应该直接传递数据,而不要传递指针。
6、COM术语; 把COM DLL称为“在进程中”,把COM EXE成为“在进程外”; 把在本地系统执行的COM EXE称为“本地服务器”; 把在别的系统执行的COM EXE称为“远程服务器”; 当使用COM访问远程的COM EXE时,实际上采用的是分布式COM技术(DCOM),而不是普通的COM技术。
怎样消灭COM对象
1、对象自己维护一个引用计数器;
2、COM也会自动清理你的COM对象; 每当创建COM对象的一个指针时,对象的引用计数加1;每当客户端用完COM对象,对象的引用计数减1; 当引用计数减到零时,COM卸载DLL或终止EXE; COM的EXE服务器自动监测客户端是否仍激活这,如果客户端的应用程序已死锁,则自动将引用计数减1; Marshalling COM数据 代理/桩子或COM DLL将方法的调用参数转化成NDR格式(网络数据表示); COM调用RPC将格式化的数据传递给服务器端的COM代理/桩子或COM DLL; 服务器端的COM代理/桩子或COM DLL将数据还原成参数表,放到调用堆栈或为指针参数而开辟的内存中; 服务器端的COM代理/桩子或COM DLL,然后调用COM服务器的方法;

转载于:https://www.cnblogs.com/shelvenn/archive/2007/12/24/1012889.html

你可能感兴趣的文章
Win7下安装Mysql(解压缩版)
查看>>
UVA 11992 Fast Matrix Operations (降维)
查看>>
Asp.net core Identity + identity server + angular 学习笔记 (第一篇)
查看>>
暂时不想读研的几点理由
查看>>
增加临时表空间组Oracle11g单实例
查看>>
Diff Two Arrays
查看>>
浅谈java垃圾回收机制
查看>>
stark组件(1):动态生成URL
查看>>
169. Majority Element
查看>>
大整数加法
查看>>
下拉菜单
查看>>
[清华集训2014]玛里苟斯
查看>>
Doctype作用?严格模式与混杂模式如何区分?它们有何意义
查看>>
0029-求最小的数
查看>>
【MVC+EasyUI实例】对数据网格的增删改查(上)
查看>>
第三章:如何建模服务
查看>>
EF CodeFirst下数据库更新
查看>>
Project Euler 345: Matrix Sum
查看>>
mysql允许远程登录
查看>>
你可能不知道的技术细节:存储过程参数传递的影响
查看>>