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传字符串解决中文乱码的解决之道。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架