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

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传字符串解决中文乱码的解决之道。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值