栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

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

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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] ='';
  
  delete []strSrc;
  delete []szRes;
  
  return len;
 }
``



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/315901.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号