小言_互联网的博客

QT基础:44---Qt中文乱码与编码问题

562人阅读  评论(0)

一、文件读写时的中文乱码问题

  • 如果文件读取时,有中文导致的乱码,可以使用QTextStream类读写文件,并设置该类的setAutoDetectUnicode(true)函数,设置自动识别Unicode编码,这样就不会显示中文乱码了

二、输入输出的中文乱码问题

  • 因为Qt Creator保存的文件使用的是UTF-8编码(是任何平台、任何语言都可以使用的跨平台的字符集),所以MSVC编译器虽然可以正常编译带BOM的UTF-8编码的源文件,但是生成的可执行文件的编码是Windows本地字符集,比如GB2312
  • 也就是在可执行文件中,字符串是以GB2312编码的,而可执行程序执行到字符串输出语句时,对这个字符串却是以UTF-8解码,这样就会出现乱码

解决办法

  • 方法一:强制MSVC编译器生成的可执行文件使用UTF-8编码。需要在每个使用到中文字符串的头文件和源程序文件的前部加入如下的语句
#if _MSC_VER >=1600
#pragma execution_character_set("utf-8")
#endif
  • 方法二:使用QStringLiteral()宏封装字符串。该宏在编译时将参数生成字符串数据,并且存储在编译后文件的只读数据段中,程序运行时使用到此字符串时,只需读出此字符串数据即可。当使用QStringLiteral()宏对字符串封装之后,就不能再使用tr()函数翻译字符串

三、编码设置

  • Windows下需要设置,Linux下不需要设置


转载:https://blog.csdn.net/qq_41453285/article/details/100016856
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场