计算机书籍控

COM技术内幕

微软公司的组件对象模型(COM)作为一种重要的工具已崭露头角,它是微软迈向分布式计算的基础。不论现在还是将来,它都是定制应用程序的一种强大的方法。并且它是OLE和ActiveX的基础。COM帮助你理解未来的程序开发技术,而这本书帮助你理解COM。在本书中你将发现:构建优美的COM组件的清晰、简单、实用的规则;COM是如何易学易用,特虽是对那些熟练掌握C++的人;循序渐进地介绍COM设计;以代码形式给出的大量实例。 
   《COM技术内幕》适合于中、高级C++程序员;COM、ActiveX和OLE程序员;对组件设计感兴趣的研究人员;以及那些当COM移植到UNIX、MVS和其他环境时想要使用到COM的程序员 

目录


引言
第1章 组件
1.1 使用组件的优点
1.1.1 应用程序定制
1.1.2 组件库
1.1.3 分布式组件
1.2 对组件的需求
1.2.1 动态链接
1.2.2 信息封装
1.3 com
1.3.1 com组件是
1.3.2 com不是
1.3.3 com库
1.3.4 com方法
1.3.5 com超越了用户的需要
1.4 本章小结
第2章 接口
2.1 接口的作用
2.1.1 可复用应用程序架构
2.1.2 com接口的其他优点
.2.2 com接口的实现
2.2.1 编码约定
2.2.2 一个完整的例子
2.2.3 非接口通信
2.2.4 实现细节
2.3 接口理论:第二部分
2.3.1 接口的不变性
2.3.2 多态
2.4 接口的背后
2.4.1 虚拟函数表
2.4.2 vtbl指针及实例数据
2.4.3 多重实例
2.4.4 不同的类,相同的vtbl
2.5 本章小结
第3章 queryinterface函数
3.1 接口查询
3.1.1 关于iunknown
3.1.2 iunknown指针的获取
3.1.3 关于querinterface
3.1.4 querinterface的使用
3.1.5 querinterface的实现
3.1.6 关于类型转换
3.1.7 一个完整的例子
3.2 关于querinterface的实现规则
3.2.1 同一iunknown
3.2.2 客户可以获取曾经得到过的接口
3.2.3 可以再次获取已经拥有的接口
3.2.4 客户可以从任何接口返回到起始接口
3.2.5 若能够从某接口获取某特定接口,则从任意接口都将能够获取此接口
3.3 querinterface定义了组件
3.3.1 接口集
3.4 新版本组件的处理
3.4.1 何时需要建立一个新版本
3.4.2 不同版本接口的命名
3.4.3 隐含合约
3.5 本章小结
第4章 引用计数
4.1 生命期控制
4.2 引用计数简介
4.2.1 引用计数简介
4.2.2 addref和release的实现
4.3 何时进行引用计数
4.3.1 引用计数的优化
4.3.2 引用计数规则
4.4 本章小结
第5章 动态链接
5.1 组件的创建
5.1.1 从dli中输出函数
5.1.2 dll的装载
5.2 客户和组件的划分
5.2.1 程序清单
5.3 对象串
5.4 本章小结
第6章 关于hresult、guid、注册表及其他细节
6.1 hresult
6.1.1 hresult值的查找
6.1.2 hresult值的使用
6.1.3 用户自己代码的定义
6.2 guid
6.2.1 为什么要使用guid
6.2.2 guid的声明和定义
6.2.3 guid的比较
6.2.4 将guid作为组件标识符
6.2.5 通过引用传递guid值
6.3 windows注册表
6.3.1 注册表的组织
6.3.2 注册表编辑器
6.3.3 clsid关键字结构
6.3.4 关于注册表的其他细节
6.3.5 progid
6.3.6 自注册
6.3.7 组件类别
6.3.8 oleview
6.4 com库函数
6.4.1 com库的初始化
6.4.2 内存管理
6.4.3 将字符串转化成guid
6.5 本章小结
第7章 类厂
7.1 cocreateinstance
7.1.1 cocreateinstance的声明
7.1.2 cocreateinstance的使用
7.1.3 类上下文
7.1.4 客户程序清单
7.1.5 cocreateinstance的不灵活性
7.2 类厂
7.2.1 cocetclassobject
7.2.2 iclassfactory
7.2.3 cocreateinstance与cogetclassobject的比较
7.2.4 类厂的若干特性
7.3 类厂的实现
7.3.1 dllgetclassobject的使用
7.3.2 组件的创建过程
7.3.3 组件代码清单
7.3.4 流程控制
7.3.5 组件的注册
7.4 同一dll中的多个组件
7.4.1 类厂实现的复用
7.5 dll的卸载
7.5.1 dllcanunloadnow的使用
7.5.2 lockserver
7.6 本章小结
第8章 组件复用:包容与聚合
8.1 包容和聚合
8.1.1 包容简介
8.1.2 聚合简介
8.1.3 包容与聚合的比较
8.2 包容的实现
8.2.1 接口扩展
8.3 聚合的实现
8.3.1 queryinterface的实现
8.3.2 不正确的iunknown
8.3.3 聚合的未知接口
8.3.4 内部组件的创建
8.3.5 外部组件中指向内部组件接口的指针
8.4 一个完整的例子
8.4.1 盲目聚合
8.5 现实世界中的聚合和包容
8.5.1 组件的内部状态信息
8.5.2 虚拟函数的模拟
8.6 本章小结
第9章 编程工作的简化
9.1 客户端的简化
9.1.1 智能接口指针
9.1.2 c++包装类
9.2 服务器端的简化
9.2.1 未知接口基类
9.2.2 类厂基类
9.2.3 cunknown和cfactory的使用
9.2.4 集成步骤
9.3 本章小结
第10章 exe中的服务器
10.1 不同的进程
10.1.1 本地过程调用
10.1.2 调整
10.1.3 代理/残根dll
10.2 idl/midl简介
10.2.1 关于idl
10.2.2 idl接口描述举例
10.2.3 midl编译器
10.3 本地服务器的实现
10.3.1 示例程序的运行
10.3.2 去掉入口点函数
10.3.3 类厂的启动
10.3.4 对lockserver的修改
10.4 远程访问能力
10.4.1 dcomcnfg.exe所完成的工作
10.4.2 工作机理
10.4.3 其他dcom信息
10.5 本章小结
第11章 调度接口与自动化
11.1 一种新的通信方式
11.1.1 旧的通信方式
11.1.2 idispatch接口
11.2 idispatch的使用
11.2.1 inuoke函数的参数
11.2.2 示例
11.2.3 variant类型
11.2.4 bstr数据类型
11.2.5 safearray类型
11.3 类型库
11.3.1 类型库的创建
11.3.2 类型库的使用
11.3.3 注册表中的类型库
11.4 idispatch接口的实现
11.4.1 异常的引发
11.4.2 参数调整
11.5 本章小结
第12章 多线程
12.1 com线程模型
12.1.1 win32线程
12.1.2 com线程
12.1.3 套间
12.1.4 套间线程
12.1.5 自由线程
12.1.6 调整与同步
12.2 套间线程的实现
12.2.1 自动调整
12.2.2 手工调整
12.2.3 编码
12.2.4 对套间线程例子的说明
12.3 自由线程的实现
12.3.1 对自由线程例子的说明
12.3.2 自由线程参数调整的优化
12.4 关于线程模型的注册表关键字
12.5 本章小结
第13章 一个完整的例子
13.1 tangram程序
13.1.1 tangram的运行
13.1.2 所用的组件
13.1.3 客户程序
13.1.4 tangrammodel组件
13.1.5 tangramgdivisual和tangramglvisual组件
13.1.6 tangramgdiworld和tangramglworld组件
13.2 展示
13.3 idl文件
13.3.1 dlidata.c文件
13.4 循环引用计数
13.4.1 不调用addref
13.4.2 使用显示终止
13.4.3 使用一个单独的组件
13.5 事件和连接点
13.5.1 ienumxxx
13.6 本章小结
结束语

书籍下载

免费下载

正版书籍

COM技术内幕