QT乱码总结7.编码测试和总结二
QT亂碼總結0.Qt亂碼產生因素
https://blog.csdn.net/liujiayu2/article/details/103167953
QT亂碼總結1.Unicode 和 UTF-8
https://blog.csdn.net/liujiayu2/article/details/103168020
QT亂碼總結2.gbk和ANSI和gb2312的區別
https://blog.csdn.net/liujiayu2/article/details/103168168
QT亂碼總結3.UNICODE有無BOM
https://blog.csdn.net/liujiayu2/article/details/103168236
QT亂碼總結4.細談本地編碼
https://blog.csdn.net/liujiayu2/article/details/103168249
QT亂碼總結5.萬能解決方案
https://blog.csdn.net/liujiayu2/article/details/103168272
QT亂碼總結6.編碼測試和總結一
https://blog.csdn.net/liujiayu2/article/details/103168289
QT亂碼總結7.編碼測試和總結二
https://blog.csdn.net/liujiayu2/article/details/103168301
QT亂碼總結8.編碼測試和總結三
https://blog.csdn.net/liujiayu2/article/details/103168307
QT亂碼總結9.編碼測試和總結四
https://blog.csdn.net/liujiayu2/article/details/103168317
QT亂碼總結編碼測試工程:
https://download.csdn.net/download/liujiayu2/11987065
?
/測試環境/
操作系統:WIN7 簡體中文版
編譯器:VS2013 中文版
QT版本:Qt 5.7
(本次測試和上次相比存在兩個變量,vs從10到13,qt從4.8.6到5.7。不是單一變量,但是也有一定參考價值)
/測試編碼
我愛中國
?
ANSI(GBK)編碼:CE D2 B0 AE D6 D0 B9 FA
?
UTF-8編碼:E6 88 91 E7 88 B1 E4 B8 AD E5 9B BD
?
UTF-8編碼(bom):EF BB BF E6 88 91 E7 88 B1 E4 B8 AD E5 9B BD
?
UNICODE編號:\u6211\u7231\u4e2d\u56fd
/
?
/測試代碼/
//#pragma execution_character_set("AAAAA")
//#pragma execution_character_set("gb2312")
#pragma execution_character_set("utf-8")
//#pragma execution_character_set("big5")
?
Widget::Widget(QWidget *parent) :
??? QWidget(parent),
??? ui(new Ui::Widget)
{
??? ui->setupUi(this);
?
??? setWindowTitle("CodecStudy_Creator");
?
?
??? QString str("我愛中國");
??? ui->lineEdit->setText(str);
?
??? std::string strStdString = str.toStdString();
??? std::wstring strStdWString = str.toStdWString();
?
??? QString hexShow;
??? for (int i=0; i<strStdString.length(); i++)
??? {
??????? unsigned char curChar= (unsigned char)strStdString.at(i) ;
?
??????? char buf[6]={0};
??????? sprintf(buf,"%02x ",curChar);
?
??????? hexShow += buf;
??? }
??? ui->lineEditHex->setText(hexShow);
?
??? QString unicodeShow;
??? QChar qcharArray[20]={0};
??? for (int i=0;i<str.count();i++)
??? {
??????? QChar qchar = str.at(i);
??????? qcharArray[i] = qchar;
?
??????? char buf[7]={0};
??????? const ushort shortChar = qchar.unicode();
??????? sprintf(buf,"\\u%04x ", shortChar);
?
??????? unicodeShow += buf;
??? }
??? ui->lineEditUnicode->setText(unicodeShow);
?
??? int a = 0;
}
/
?
/
測試1:
文件編碼:ANSI
使用編碼函數或方式:無
測試結果:
總結:
雖然還是亂碼,但是看得出來和上次測試亂碼亂出來的字符不一樣,猜測這種加載方式不是按照Latin-1進行加載的。
/
測試2:
文件編碼:UTF-8沒有BOM
使用編碼函數或方式:無
測試結果:
總結:
出現正常編碼很是意外,那就說明Qt5.7+VS2013是中的QString默認是按照utf-8進行加載的。但是究竟是qt5.7發生了改變哈市vs2013發生了改變我們不得而知,但是大膽猜測是QT5.7相比較qt4.8.6而發生的改變。
/
測試3:
文件編碼:UTF-8有BOM
使用編碼函數或方式:無
測試結果:
總結:
從十六進制可以看出,文件編碼采用帶有BOM的utf-8編碼的時候,字符串進行編碼的時候采用的是本地編碼gbk而不是utf-8編碼。說明問題無論QT版本怎么變,或者vs版本怎么變,帶有BOM的utf-8總是和本地編碼gbk一致。
/
測試6:
使用編碼函數或方式:QString::fromLocal8Bit
文件編碼:ANSI、UNICODE無BOM、UNICODE有BOM
測試結果:
QString::fromLocal8Bit + ANSI文件(或者UNICODE帶BOM) =? 正確顯示
QString::fromLocal8Bit + UNICODE不帶BOM文件? =? 亂碼
原因分析:
和上次結果一致。只是默認采用的加載編碼不一樣。一旦指定了加載編碼,那就都一樣咯。
/
測試10:
使用編碼函數或方式:QObject::tr
文件編碼:ANSI、UNICODE無BOM、UNICODE有BOM
測試結果:
有與沒有完全一樣。
這個很奇怪,上篇講到這個函數是和QTextCodec::setCodecForTr聯合使用的,為什么去掉了setCodecForTr卻沒有去掉QObject::tr???
/
測試11:
使用編碼函數或方式:QObject:: trUtf8
文件編碼:ANSI、UNICODE無BOM、UNICODE有BOM
測試結果:
效果等同與QString::fromUtf8(),這種環境下本身默認就是這樣加載的,所以有與沒有效果完全一樣。
/
測試12:
使用編碼函數或方式:#pragma execution_character_set("utf-8")
文件編碼:ANSI、UNICODE無BOM、UNICODE有BOM
測試結果:
ANSI + #pragma execution_character_set("utf-8") ?= 正常
UNICODE無BOM + #pragma execution_character_set("utf-8")? = 亂碼
總結1:
使用了#pragma execution_character_set("utf-8") 起到了明顯作用
?
ANSI + #pragma execution_character_set("gb2312")? = 亂碼
UNICODE無BOM + #pragma execution_character_set("gb2312")? =正常
總結2:
使用了#pragma execution_character_set("2312") 不起作用
?
?
?
總結
以上是生活随笔為你收集整理的QT乱码总结7.编码测试和总结二的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: QT乱码总结6.编码测试和总结一
- 下一篇: QT乱码总结8.编码测试和总结三