C#调用C/C++DLL收取中文字符处理

发表于:2016-7-15 09:56

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:ccqin    来源:51Testing软件测试网采编

  C#可以通过P/Invoke调用C/C++写的DLL,一般在从DLL接收字符串时比较麻烦,本人在某个项目中就遇到这个问题,
  从DLL收读取字符串时遇到中文乱码,这里总结一下C#收取字符串时的处理。
  C/C++字符串一般通过char* 或wchar_t*来表示,char*表示的是ANSCII字符串, wchar_t*表示Unicode字符串,Unicode字符串在C/C++中一个字符占用两个字节,ANSII字符串一个字符占用一个字节(中文占用两个字节), 如果C++的接口声明为char*的入口参数时,C#需要使用byte[] 数组来表示字节缓冲, 注意C#中char 是占用两个字节的。
  比如C++中接口原型
  void testStr(char *buf, int size);
  在C#中作如下的原型声明
  [Dllimport("yourdll.dll")]
  extern int testStr(IntPtr buf, int size);
  作如下调用
  byte[] buf = new byte[LEN];
  int len = testStr(Marshal.UnsafeAddrOfPinnedArrayElement(buf, 0), buf.length);
  byte[] cvtBuf = new byte[LEN];
  //重点在于这里的转换 这里是将默认的编码ANSII转换为unicode编码。适用于char* ->unicode
  //如果是_TCHAR或wchar_t表示的字符串,不妨用char[]作为缓冲传入
  cvtBuf = Encoding.Convert(Encoding.Default, Encoding.Unicode, buf , 0, len-1);
  string recvStr = Marshal.PtrToStringAuto(Marshal.UnsafeAddrOfPinnedArrayElement(cvtBuf , 0));
  至此中文字符传入到C#就能正常地显示了。
  C++中有个编码转换比较有用的函数WideCharToMultiByte和MultiByteToWideChar,可以在MSDN中找到它.
  它也是从C/C++动态库通过JNI向Java传字符串解决中文乱码的解决之道。
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号