第六节、接口转换
c#中不仅支持.net 平台,而且支持com平台。为了支持 com和.net,c# 包含一种称为属性的独特语言特性。一个属性实际上就是一个 c# 类,它通过修饰源代码来提供元信息。属性使 c# 能够支持特定的技术,如 com 和 .net,而不会干扰语言规范本身。c# 提供将com接口转换为 c#接口的属性类。另一些属性类将 com类转换为c# 类。执行这些转换不需要任何 idl 或类工厂。
现在部署的任何com 组件都可以在接口转换中使用。通常情况下,所需的调整是完全自动进行的。
特别是,可以使用运行时可调用包装 (rcw) 从 .net 框架访问 com 组件。此包装将 com 组件提供的 com 接口转换为与 .net 框架兼容的接口。对于 ole 自动化接口,rcw 可以从类型库中自动生成;对于非 ole 自动化接口,开发人员可以编写自定义 rcw,手动将 com 接口提供的类型映射为与 .net 框架兼容的类型。
使用comimport引用com组件
com interop 提供对现有 com 组件的访问,而不需要修改原始组件。使用comimport引用com组件常包括下面 几个方面的问题:
1、创建 com 对象。
2、确定 com 接口是否由对象实现。
3、调用 com 接口上的方法。
4、实现可由 com 客户端调用的对象和接口。
创建 com 类包装
要使 c# 代码引用com 对象和接口,需要在 c# 中包含 com 接口的定义。完成此操作的最简单方法是使用 tlbimp.exe(类型库导入程序),它是一个包括在 .net 框架 sdk 中的命令行工具。tlbimp 将 com 类型库转换为 .net 框架元数据,从而有效地创建一个可以从任何托管语言调用的托管包装。用 tlbimp 创建的 .net 框架元数据可以通过 /r 编译器选项包括在 c# 内部版本中。如果使用 visual studio 开发环境,则只需添加对 com 类型库的引用,将为您自动完成此转换。
tlbimp 执行下列转换:
1、com coclass 转换为具有无参数构造函数的 c# 类。
2、com 结构转换为具有公共字段的 c# 结构。
检查 tlbimp 输出的一种很好的方法是运行 .net 框架 sdk 命令行工具 ildasm.exe(microsoft 中间语言反汇编程序)来查看转换结果。
虽然 tlbimp 是将 com 定义转换为 c# 的首选方法,但也不是任何时候都可以使用它(例如,在没有 com 定义的类型库时或者 tlbimp 无法处理类型库中的定义时,就不能使用该方法)。在这些情况下,另一种方法是使用 c# 属性在 c# 源代码中手动定义 com 定义。创建 c# 源映射后,只需编译 c# 源代码就可产生托管包装。
执行 com 映射需要理解的主要属性包括:
1、comimport:它将类标记为在外部实现的 com 类。
2、guid:它用于为类或接口指定通用唯一标识符 (uuid)。
3、interfacetype,它指定接口是从 iunknown 还是从 idispatch 派生。
4、preservesig,它指定是否应将本机返回值从 hresult 转换为 .net 框架异常。
声明 com coclass
com coclass 在 c# 中表示为类。这些类必须具有与其关联的 comimport 属性。下列限制适用于这些类:
1、类不能从任何其他类继承。
2、类不能实现任何接口。
4、类还必须具有为其设置全局唯一标识符 (guid) 的 guid 属性。
以下示例在 c# 中声明一个 coclass:
// 声明一个com类 filgraphmanager
[comimport, guid("e436ebb3-524f-11ce-9f53-0020af0ba770")]
class filgraphmanager
{ }
c# 编译器将添加一个无参数构造函数,可以调用此构造函数来创建 com coclass 的实例。
共4页: 上一页 1 [2] [3] [4] 下一页
新闻热点
疑难解答