1.问题描述: 这周,公司的上位机软件在笔记本上连接串口接收数据时crash掉了,之所以crash掉,究其原因,是自己的代码不够健壮,没有考虑到特殊情况,比如消息丢失的时候再去按照某个标志(如逗号)解析相应字段的时候肯定会crash掉,内存访问越界嘛。为什么在台式机上测试时从没出过问题呢,再究其原因,笔记本没有串口,是使用usb-to-serial port生成的虚拟串口,可能公司买的转接头质量比较差,也可能是附带的驱动程序有问题,导致过一段时间就会丢数据,还是持续性的。接下来当然就是修改代码,使其至少不能crash掉,再下来就是一直检测发现丢消息超过5条时,重新初始化串口,即close, reopen. 这样子就不会持续性的丢消息。修改代码的过程中又发现了如下问题:
a. 在打开原有串口(一般都是COM1)时,CreateFile时使用_T("COM1")就可以了,可是打开虚拟串口(比如COM15)时,需要使用(.//COM15")才可以,不然的话会返回错误代码2--找不到指定设备。
b.在使用虚拟串口的计算机上运行上位机时,需要不停的检测可用的串口号,因为只有你插上usb设备的时候,系统才会分配一个串口号,所以在运行上位机的时候生成一个线程来检测可用的串口,当然,这个线程的优先级可以设得稍微低一点,检测到了,就添加到可用列表末尾,直到应用程序退出。