C#调C++动态类库(DLL)分析和总结.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
在 C#调用 C++编写的 COM DLL 封装库时会出现两个问题: 数据类型转换问题 指针或地址参数传送问题 首先是数据类型转换问题。因为 C#是.NET 语言,利用的是.NET 的基本数据类型,所以实际上是将 C++的数据类型与.NET 的基本数据类型进行对应。 例如 C++的原有函数是: int stdcall FunctionName(unsigned char param1, unsigned short param2) 其中的参数数据类型在 C#中,必须转为对应的数据类型。如: [DllImport(“ COM DLL path/file ”)] extern static int FunctionName(byte param1, ushort param2) 因为调用的是 stdcall 函数,所以使用了 P/Invoke 的调用方法。其中的方法FunctionName 必须声明为静态外部函数,即加上 extern static 声明头。我们可以看到,在调用的过程中,unsigned char 变为了 byte,unsigned short 变为了 ushort。变换后,参数的数据类型不变,只是声明方式必须改为.NET 语言的规范。 我们可以通过下表来进行这种转换: Win32 Types Win32 Types char, INT8, SBYTE, CHAR short, short int, INT16, SHORT CLR Type System.SByte System.Int16 int, long, long int, INT32, LONG32, System.Int32 BOOL , INT int64, INT64, LONGLONG System.Int64 unsigned char, UINT8, UCHAR , System.Byte BYTE unsigned short, UINT16, USHORT, System.UInt16 WORD, ATOM, WCHAR , wchar_t unsigned, unsigned int, UINT32, ULONG32, DWORD32, ULONG, DWORD, UINT unsigned int64, UINT64, DWORDLONG, ULONGLONG float, FLOAT double, long double, DOUBLE System.UInt32 System.UInt64 System.Single System.Double 之后再将 CLR 的数据类型表示方式转换为 C#的表示方式。这样一来,函数的参数类型问题就可以解决了。 现在,我们再来考虑下一个问题,如果要调用的函数参数是指针或是地址变量,怎么办? 对于这种情况可以使用 C#提供的非安全代码来进行解决,但是,毕竟是非托管代码,垃圾资源处理不好的话对应用程序是很不利的。所以还是使用 C#提供的 ref 以及 out 修饰字比较好。 同上面一样,我们也举一个例子: int stdcall FunctionName(unsigned char param1, unsigned char *param2) 在 C#中对其进行调用的方法是: [DllImport(“ COM DLL path/file ”)] extern static int FunctionName(ref byte param1, ref byte param2) 看到这,可能有人会问,是取地址,*是传送指针,为何都只用 ref 就可以了呢?一种可能的解释是 ref 是一个具有重载特性的修饰符,会自动识别是取地址还是传送指针。 在实际的情况中,我们利用参数传递地址更多还是用在传送数组首地址上。如:byte[] param1 = new param1(6); 在这里我们声明了一个数组,现在要将其的首地址传送过去,只要将 param1 数组的第一个元素用 ref 修饰。具体如下: [DllImport(“ COM DLL path/file ”)] extern static int FunctionName(ref byte param1[1], ref byte param2) 一、发生的背景 一、发生的背景 在开发新项目中使用了新的语言开发 C# 和新的技术方案 WEB Service,但是在新 项目中,一些旧的模块需要继续使用,一般是采用 C 或 C++ 或 Delphi 编写的,如何利用旧模块对于开 发人员来说,有三种可用方法供选择: 第一、将 C 或 C++ 函数用 C# 彻底改写一遍,这样整个项目 代码比较统一,维护也方便一些。但是尽管微软以及某些书籍说,C

文档评论(0)

hao187 + 关注
官方认证
文档贡献者

该用户很懒,什么也没介绍

认证主体武汉豪锦宏商务信息咨询服务有限公司
IP属地上海
统一社会信用代码/组织机构代码
91420100MA4F3KHG8Q

1亿VIP精品文档

相关文档