QT中文问题

字节顺序标记(BOM)
出现在字节流的开头,在windows下保存UTF-8编码的文件时,会在开始的地方插入 BOM(0xEF,0xBB,0xBF),让编辑器识别文件是否为UTF-8编码。而标准的UFT-8是不带BOM的。也就是说,如果再Linux系统下,文件编码格式可以忽略BOM。。
注意:在Qtcreator(Linux平台下)中的“Tool”->"Options"下设置“UTF-8 BOM”时不要选择“Add If Encoding Is UTF-8“,如果选择这一项,在写代码的时候会添加BOM,而这样在编译的时候就会报错。

几种编码格式
UTF-8
Unicode TransformationFormat-8bit,允许含BOM,但标准的UTF-8不含BOM,用来统一国际上的字符,通用性强,属于国际编码,它对英文使用8位(即一个字节),中文使用24为(三个字节)来编码。UTF-8编码的文字可以在各国支持UTF8字符集的浏览器上显示。如果是UTF8编码,则在外国人的英文IE上也能显示中文,他们无需下载IE的中文语言支持包。

GBK /GB2312
GBK是国家标准GB2312基础上扩容后兼容GB2312的标准。GBK的文字编码是用双字节来表示的,即不论中、英文字符均使用双字节来表示,为了区分中文,将其最高位都设定成1。GBK包含全部中文字符,是国家编码,通用性比UTF8差。
Unicode
Unicode中存储了很多种编码的字符,它可以看做是很多种编码格式的集合。
乱码产生的原因
文件的编码格式有多种,因此同一的二进制文件可以被翻译成不同的符号。那么当一个文件用这种编码方式编辑但是却使用另一中编码方式打开的时候,就会出现乱码,而产生乱码的原因就是两种编码格式的字符的存储方式是不同的。
那么在Qt中出现乱码是怎么回事呢?
Linux平台下的Qtcreator的编码格式是UTF-8,中文使用三个字节来编码;而Qt中的QString使用Unicode来编码的。Unicode中有很多种编码格式的字符。那么当把一串中文赋值给QString定义的变量A时,就会存在一个问题,这串文字是以一种什么样的编码存储到Unicode中的?如果是以UTF-8的方式存储的,那么Qt上的字体就会显示正常;如果是以其他的编码方式存储的则会出现乱码。
在Qt程序中,如果不指明使用哪种编码存储到Unicode,那么会默认Latin-1编码,这样在Qt显示中文的时候就会出现乱码!

因此当在程序中贴上上图的几行代码时,其作用就是指明程序中的中文使用哪种编码存储到Unicode中

QT 显示中文的三种方法
最近在用Qt做项目,遇到UI不能显示中文的问题,发现有3种方法可以解决,先记录一下

方法一
QString::fromLocal8Bit("你好中国")

方法二
QStringLiteral("你好中国")

方法三
在.cpp中加入
#pragma execution_character_set("utf-8")
然后正常输入中文(“你好中国”)

你可能感兴趣的:(C++,QT5)