CodeBlocks控制台中文乱码

中文乱码是个老问题了,涉及乱码的问题无非是编码不统一造成的;

涉及编码的地方常见有:

1. 源文件本身编码

2. 编译器读取源文件编码

3. 数据编码(数据库,IO文件等)

4. 执行输出编码

 

知道乱码的原因有利于解决乱码问题,这些原因在哪个IDE都是通用的

 

关于codeblock这款IDE,这里就不说数据库那些编码了,一般写大点的C/C++项目也不会用这种开源免费的工具;


第一步:解决文件本身乱码

如果源码是用codeblock编写的,打开Setting->Editor->General Setting->Ecoding Setting设置如图:

 CodeBlocks控制台中文乱码_第1张图片

Use encoding when opening files:表示打开文件和第一次保存文件用的编码格式。

As default encoding:表示文件缺省保存和打开编码格式。

如果源文件不是codeblock编写的,就把上面UTF-8换成和原来文件一致的编码;或者用其他工具转成UTF-8(比如notepad

 

第二步: 解决编译器读取源文件编码

这里使用GCC编译器,打开Setting->Compiler->Global compiler setting->Compiler setting -> other compiler options;

添加一行:

-finput-charset=UTF-8

如下图

 CodeBlocks控制台中文乱码_第2张图片

注:这里设置为UTF-8是因为上面第一步设置的源文件编码为UTF-8,如果不是需要两个地方一致;

 

第三步: 设置执行输出编码

如果机器是windows系统的,需要看看控制台的编码,博主控制台属性如图:

 CodeBlocks控制台中文乱码_第3张图片

看当前代码页: 936 (ANSI/OEM - 简体中文 GBK)

那么C/C++的执行应该也是要和这里一致的。

还是打开Setting->Compiler->Global compiler setting->Compiler setting -> other compiler options;

添加一行:

-fexec-charset=GBK

如下图:

 CodeBlocks控制台中文乱码_第4张图片

这样,控制台输出的中文就不会乱码了。

 

【转载】,原文传送门:https://blog.csdn.net/Fantastic_/article/details/74563680

你可能感兴趣的:(C++,codeblocks,中文乱码,编码不统一)