编码设置
CodeBlocks编码
Setting->Editor…->General settings->Other settings->Encoding
gcc文件编码
Setting->Compiler->Compiler settings->Other Options:
-finput-charset=UTF-8
-fexec-charset=UTF-8
-finput-charset=GBK
-fexec-charset=GBK
控制台编码
cmd 下 输入 chcp
936 -> GBK-936
65001 -> UTF-8
控制台更改为UTF-8
windows默认936
cmd输入chcp 65001 然后右键cmd标题栏->属性->字体->选择Lucida Console和合适的字体大小 点击确定.关闭cmd
GBK中文乱码
检查CodeBlocks中编码设置和windows设置是否一致.
因为windows默认编码是GBK-936,所以将Editor->…Encoding改成GBK-936.[gcc文件编码]改成GBK.
CodeBlocks使用UTF-8编码
将Editor->…Encoding改成UTF-8.gcc文件编码(参考上面的)改成utf-8.
UTF-8中文乱码完美解决方案
写代码的时候,utf8,多字节.都是使用char []来保存数据.但是内部编码不同. code blocks使用utf-8编码, 输出的信息也是utf8,但是控制台会把字符串当做多字节编码来处理,所以会产生乱码.
将utf-8转换成多字节编码,然后再用printf/cout…等等函数 输出数据就是正常的了.
http://blog.csdn.net/czy463/article/details/47060759
//转换文字ACP编码为Utf8编码
inline void ConvertACPToUtf8(char*szAcp, int nAcpLen, char *szUtf8, int nUtf8Len)
{
int len=MultiByteToWideChar(CP_ACP, 0, szAcp, -1, NULL,0);
unsigned short * wszUtf8 = new unsigned short[len+1];
memset(wszUtf8, 0, len * 2 + 2);
MultiByteToWideChar(CP_ACP, 0, (LPCTSTR)szAcp, -1, (LPWSTR)wszUtf8, len);
len = WideCharToMultiByte(CP_UTF8, 0, (LPCWSTR)wszUtf8, -1, NULL, 0, NULL, NULL);
memset(szUtf8, 0, nUtf8Len);
if(len <= nUtf8Len)
{
WideCharToMultiByte (CP_UTF8, 0, (LPCWSTR)wszUtf8, -1, szUtf8, len, NULL,NULL);
}
else
{
WideCharToMultiByte (CP_UTF8, 0, (LPCWSTR)wszUtf8, -1, szUtf8, nUtf8Len-1, NULL,NULL);
}
delete[] wszUtf8;
}
//转换文字Utf8编码为ACP编码
inline void ConvertUtf8ToACP(char *szUtf8, int nUtf8Len,char *szAcp, int nAcpLen)
{
int len=MultiByteToWideChar(CP_UTF8, 0, (LPCTSTR)szUtf8, -1, NULL,0);
unsigned short * wszGBK = new unsigned short[len+1];
memset(wszGBK, 0, len * 2 + 2);
MultiByteToWideChar(CP_UTF8, 0, (LPCTSTR)szUtf8, -1, (LPWSTR)wszGBK, len);
len = WideCharToMultiByte(CP_ACP, 0, (LPWSTR)wszGBK, -1, NULL, 0, NULL, NULL);
memset(szAcp, 0, nAcpLen);
if(len <= nAcpLen)
{
WideCharToMultiByte (CP_ACP, 0, (LPWSTR)wszGBK, -1, szAcp, len, NULL,NULL);
}
else
{
WideCharToMultiByte (CP_ACP, 0, (LPWSTR)wszGBK, -1, szAcp, nAcpLen-1, NULL,NULL);
}
delete[] wszGBK;
}
UTF-8编码.控制台乱码
CodeBlocks控制台使用的是其根目录下cb_console_runner.exe程序来启动程序. 这个程序会使用windows默认编码.如果将编码改成UTF-8,就会出现乱码. 解决方式:
1. 在程序中使用system(“chcp 65001”),这样只会改变当前输出的控制台窗口.但是测试后发现,输出几次之后,就不再输出信息了.
2. 将cb_console_runner.exe改名.更改控制台全局默认为UTF-8
(chcp 65001).