codeblocks中文乱码问题

第一步

		点开设置-->编辑器-->encoding settings

codeblocks中文乱码问题_第1张图片

		设置编码为UTF-8,点击确定

第二步

		打开设置-->编译器设置-->Other compiler options

codeblocks中文乱码问题_第2张图片

输入:

-finput-charset=UTF-8
-fexec-charset=GBK

设置之后,需要随便改动一下代码重新编译即可。

-finput-charset用来指定输入文件的的字符编码,如果不指定,将无法将L“中文"这样的字符正确转化为宽字符。相反,未指定输入文件的字符编码时,MinGW编译环境下的gcc将按本地字符编码解析源文件,将普通字符串仍然按照文件使用的本地字符编码编入程序,并将含有宽字符标量L的字符串按照本地编码来识别并转为UTF-8编码(很奇怪,它不是转为UNICODE编码,反而,在指定了源文件的字符集之后却转为了UTF-16编码。同时,这种不指定源文件编码方式却使用宽字符标量L指明编译器要将特定字符串转换成UNICODE编码的行为将会带来一个警告,而不是编译报错)。-fexec-charset指定了字符串所使用的格式。
比如说,如果源文件保存的是GBK格式的,那么编译成程序时,其中的字符串就是GBK编码的。但是如果你的程序其实需要字符串按UTF-8来编码,那么就可以指定编译选项-fexec-charset=UTF-8 -finput-charset=GBK

出现如下错误

在这里插入图片描述

codeblocks中文乱码问题_第3张图片

此种错误,可能程序本身没有语法错误,应该是每一行的空格的编码不对,只需要将程序出错行前面的空格删掉,然后让程序再退回即可解决问题!

一般是编码不一致导致,通常是从网上复制下来的代码,导致网页编码不同,编译器不识别导致。

出现"error:converting to execution character set illegal sequence"

也是编码的问题
在编译器中设置
-finput-charset=UTF-8
然后随便改动一下代码重新编译即可。

你可能感兴趣的:(codeblocks中文乱码问题)