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