qt是跨平台的开发平台。他的编译器是要手动配置的,在window下一般我们用virtual stuido中cl,或者Mingw中的g++
在linux中一般采用Linux下的g++
而 微软VS的中的cl,Mingw中的g++,Linux下的g++),源代码分别采用 GBK 和 不带BOM的UTF-8 以及 带BOM的UTF-8 这3中编码进行保存。
也就是说编译器的编码方式是不同的,所以大部分情况我们在qt代码中写中文时就会有乱码
网上搜索得出
这两段代码可以解决大部分的乱码问题。(记得加入#include<QTextCodec> 头文件引用)
QTextCodec::setCodecForCStrings(QTextCodec::codecForName("GBK"));
QTextCodec::setCodecForCStrings(QTextCodec::codecForName("UTF-8"));
其实上面的代码的意思是告诉编译器我们用什么样的编码方式来解读我们写的代码。 一般在使用微软的编译器 我们在main函数中
QApplicationa(argc,argv);之后加入QTextCodec::setCodecForCStrings(QTextCodec::codecForName("GBK"));。
使用g++编译器我们使用QTextCodec::setCodecForCStrings(QTextCodec::codecForName("UTF-8"));
第2种方法
Qt5中,一些函数已经被取消了,而且网上很多都是不推荐这种写法。所以当时找到的是自行转换:
QTextCodec * BianMa = QTextCodec::codecForName ( "GBK" );
QMessageBox::information(this, "提示", BianMa->toUnicode("中文显示!"));
其实也可以通过QString定义的静态函数,先转换成Unicode类型:
QString::fromLocal8Bit("提示")
不过在Qt5中,提供了一个专门的处理宏,来支持中文常量,那就是QStringLiteral,但它只能处理常量。
QMessageBox::information(this, QString::fromLocal8Bit("提示"), QStringLiteral("中文显示"));
const char* info = "中文显示";
//不支持
QString strInfo = QStringLiteral(info);
//支持
QString strInfo = QString::fromLocal8Bit(info);
对于中文常量,使用QStringLiteral即可解决,对于字符串变量,使用QString自带函数也可以轻松解决。