Windows系统中文乱码,最简单解决方案,调用函数即可!

乱码原因

windows下控制台的编码使用的是系统的默认编码,通常情况下是ANSI(GBK),如果输出乱码,那就是源文件编码和该编码不一致。

解决方法一(不推荐)

这种方式简单但不推荐,就是将你的源文件和系统默认编码改成一样。但这种方法的问题在于,如果有人在其他编码的环境(linux,osx下默认基本是utf8编码)下查看你的源码,他们看到的是乱码。

解决方法二(推荐)

麻烦一点,但是是个好习惯,用utf8编码的源文件,将utf8编码转成GBK后输出,win32下用MultiByteToWideChar,WideCharToMultiByte,或者用c++11提供的codecvt库。

封装好的函数

int UTF8ToGB(const char* str,char *out)
 {
  WCHAR *strSrc;
  TCHAR *szRes;
  int len;
  
  //获得临时变量的大小
  int i = MultiByteToWideChar(CP_UTF8, 0, str, -1, NULL, 0);
  strSrc = new WCHAR[i+1];
  MultiByteToWideChar(CP_UTF8, 0, str, -1, strSrc, i);
  
  //获得临时变量的大小
  i = WideCharToMultiByte(CP_ACP, 0, strSrc, -1, NULL, 0, NULL, NULL);
  szRes = new TCHAR[i+1];
  WideCharToMultiByte(CP_ACP, 0, strSrc, -1, szRes, i, NULL, NULL);
  
  len = (i+1)*sizeof(CHAR);
  memcpy(out,szRes,len);
  out[len+1] ='\0';
  
  delete []strSrc;
  delete []szRes;
  
  return len;
 }
``



你可能感兴趣的:(Windows开发及安全攻防,windows,linux,c++)