问题现象
我在做串口通讯数据交互时,上位机读取串口数据,正常情况下应该返回十六进制字符串“AA550A000000000000000033”,报文具体含义我就不解释了,不是本文的重点。但是我所编写的上位机软件代码总是不能读取全部内容,只能读取到十六进制字符串“AA550A”,而且没有报错。
用串口调试助手却又能够正确读取全部长度的报文内容,然后用其他的指令返回的内容又都正确无误,只有这一条返回内容是不完整的,这让我很困惑,思考了良久依旧没有找到问题根源。
问题根源
我将十六进制字符串“0A“转换成正常显示的字符串后,才发现原来“0A”就是换行符,
这样的一个偶然的机会我才想到,原来是我的串口通讯配置没有忽略终止符号。
解决办法
将串口配置函数的接线端“Enable Termination Char(T)”的值设置为false,忽略终止符,这样问题就迎刃而解了。
因为“Enable Termination Char”默认是true,我们平常也不会修改它的值,一般读取的串口数据也不会有终止符,但是这次真的很巧,我们读取的十六进制0A就是换行符,导致程序还未读取全部串口返回数据就提前结束了。
工作上的一次问题处理分析过程,分享给大家,如果以后遇到同样的问题,大家也可以参考本文去处理。