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传字符串解决中文乱码的解决之道。


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM