根据上篇文章的说明,我已经发现在Linux系统的串口通信中,发送的16进制数据包中当有大于一定值的情况时,在Clion 中编译就会报错(该编译器属于Qt 5.8 MingW )的现象。经过自己一番尝试和查找,已经解决了编译报错的情况。
请看以下代码:
char data[9] = {0x11,0x22,0x33,0x11,0x22,0x33,0x11,0x22,(char)0x88};为什么这样就可以编译通过,目前我也不是很清楚,只是认为对于以上的数据构成情况时,可能其数据类型有默认的类型,因而导致报错。
error: narrowing conversion of ‘136’ from ‘int’ to ‘char’ inside { } [-Wnarrowing]但是,我又发现了一个新的问题。
原来我以为当要发送的16进制数据包中,一旦前半位有大于等于8时,就会编译报错。但是我后来又尝试了其他的情况,最终发现
1. 当发送数组中的数据属于这种样式时,编译会报错(0x80,0x90,0xA0...): narrowing conversion of data from ‘int’ to ‘char’ inside { } [-Wnarrowing]
2. 当发送数组中的数据属于这种样式时,编译就不会报错(0x08,0x08,0x0A...)
3. 当发送数组中的数据符合第一种情况时,将char 数组写成以下格式便可编译通过:char data[9] = {0x11,0x22,0x33,0x11,0x22,0x33,0x11,0x22,(char)0x88};
因此,我认为编译器报错很可能和16进制数据的最高位数有关(这可能和我的串口属性配置有关)。
具体的,还在研究中。。。
若有兴趣的话,欢迎大家一起来交流学习。
本文探讨了在Linux环境下使用Clion编译含有特定16进制数据的串口通信程序时遇到的问题,并分享了解决方案。文章详细分析了导致编译错误的原因,并给出了一种可行的数据定义方式。
8681

被折叠的 条评论
为什么被折叠?



