最近,QT项目遇到这样一个问题:
1.将某个 QString 变量转换成 char * 变量。
2.将char * 变量 转换成 QString 。
然后,测试发现,如果第一步的QString含中文,那么,得到的char * 变量就会乱码。
部分代码如下:
main()函数中设置编码:
QTextCodec::setCodecForTr(QTextCodec::codecForName("utf-8"));
QTextCodec::setCodecForCStrings(QTextCodec::codecForName("utf-8"));
QTextCodec::setCodecForLocale(QTextCodec::codecForName("utf-8"));
将QString转换成char * 过程:
QString str = "中文测试";
QByteArray temp = str.toLocal8bit();
char *name = temp.data();
qDebug()<<"name: "<<name;
运行后的打印的结果显示是乱码的。
解决方法:
方法一:先将QString转换为标准库中的string类型,然后将string转换为char*,如下:
std::string str = filename.toStdString();
const char* ch = str.c_str();
经测试,没有出现中文乱码。
方法二:Qt中,很多时候,我们用 char* ch 变量去显示到界面时,都会先将其转换成QString。如果直接使用强转换QString(ch),得到的结果会是乱码。但是,使用如下方法转换即可解决问题,代码如下:
1.设置编码:
QTextCodec::setCodecForTr(QTextCodec::codecForName("utf-8"));
QTextCodec::setCodecForCStrings(QTextCodec::codecForName("utf-8"));
QTextCodec::setCodecForLocale(QTextCodec::codecForName("utf-8"));
2.将QString转换成char * 过程:
QString str = "中文测试";
QByteArray temp = str.toLocal8Bit();
char *name = temp.data();
qDebug()<<"name: "<<name;
尽管此时qDebug()输出显示的是乱码,但是假如这里的name 只是作为一个中间变量,是为了调用某些接口而使用的,最后还是需要将 name 转换会 QString 供界面显示。那么我们可以忽略这个name变量的乱码问题,只需要关注:最后将name转换为QString时,不会乱码就行。
3.将char* 转换为 QString
char name[256];
memset(name,0,sizeof(name));
getFileName(name); //从某个地方获取name,自定义
QString str = QString::fromLocal8Bit(name); //转换成QString,供界面显示。
//此处如果直接使用强制转换QString str = QString(name),会出现乱码。
所以,关键在于 toLocal8Bit() 以及 fromLocal8Bit() 的配套使用。