博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
关于QT中奇数个汉字出现newline in constant的错误
阅读量:4043 次
发布时间:2019-05-24

本文共 1263 字,大约阅读时间需要 4 分钟。

前面写了一篇关于QT中使用汉字的博客以为对汉字的使用了如指掌, 没想到今天把字符串一换, 换成偶数个没问题, 换成奇数个汉字, 哇擦, 报一个错误newline in constant, 瞬间意识到自己还是太年轻.

 

好了, 开始正题

 

先说下 在QT Creator可能出现的乱码的情况:

 

1. 打开文件时, 汉字就是乱码, 这种情况是因为你向文件写汉字的时候,文件是一套编码(比如GB2312), 然后读取文件的时候却用另一套编码来读(比如UTF-8), 就会出现这种情况, 解决方法很简单,就是把写和读时的编码方式设成一致

 

2. 文件显示正常, 却报错"newline in constant"或者"常量中有换行符"? 这种情况,往往出现在奇数个汉字中. 这是为什么呢? 这是MSVC在编译时的解读问题, MSVC在解读文件时会根据文件有没有BOM, (关于什么是BOM请参考链接1), 如果有BOM,那么按照BOM的方式去解读, 如果没有BOM,那么按照本地编码( 对于简体中文的Windows操作系统就是GB2312)去解读.因此我们的问题就出现了, 一般我的QT Creator中的项目editor设置里面默认编码是UTF-8,BOM里呢如果存在则保留. 但是如果不存在呢? 所以解决方法就是把设置为add if encoding is UTF-8, 再运行, OKAY, 完美.

 

注意思

 

 

3. 编译正常通过, 生成出来的程序却是乱码.  或者用qDebug()输出的中文时, 文件中显示正常, 显示出来是乱码. 这是因为MSVC生成的可执行文件是本地编码(GB2312), 而QT会以UTF-8编码来识别GB2312的文字. 解决方式就是在文件头加上

#if _MSC_VER >= 1600

#pragma execution_character_set("utf-8")
#endif

这个宏告诉MSVC,执行程序中字符的编码采用UTF-8,别用本地的编码

 

最后需要注意的时候,当你执行windows API的时候, API里面的比较一般会使用本地编码 , 所以使用类似FindWindow这样的API时, 字符串最好转成本地编码的形式

QString string1 =  "我好帅";

HWND hMain = FindWindow(NULL, string1.toLocal8Bit());//找窗口句柄

 

注意当用了#pragma execution_character_set("utf-8")这句之后

QString::toLocal8BIT() 依然是GB2312

toLocal8BIT会转成

 

 

参考链接1:http://liuweilhy.blog.163.com/blog/static/11405670201510901627229/

参考链接2:http://www.cnblogs.com/gudi/p/4086183.html

 

 

update on 23/03/2020:

注意文件编码的修改: 

你可能感兴趣的文章
SQL 多表联合查询
查看>>
Visual Studio 2010:C++0x新特性
查看>>
drwtsn32.exe和adplus.vbs进行dump文件抓取
查看>>
cppcheck c++静态代码检查
查看>>
在C++中使用Lua
查看>>
一些socket的编程经验
查看>>
socket编程中select的使用
查看>>
关于AIS编码解码的两个小问题
查看>>
GitHub 万星推荐:黑客成长技术清单
查看>>
可以在线C++编译的工具站点
查看>>
关于无人驾驶的过去、现在以及未来,看这篇文章就够了!
查看>>
所谓的进步和提升,就是完成认知升级
查看>>
昨夜今晨最大八卦终于坐实——人类首次直接探测到了引力波
查看>>
为什么读了很多书,却学不到什么东西?
查看>>
长文干货:如何轻松应对工作中最棘手的13种场景?
查看>>
如何用好碎片化时间,让思维更有效率?
查看>>
No.147 - LeetCode1108
查看>>
No.174 - LeetCode1305 - 合并两个搜索树
查看>>
No.175 - LeetCode1306
查看>>
No.176 - LeetCode1309
查看>>