CSerialPort不能连续发送的问题

通过注释掉CSerialPort::WriteChar中清空缓冲区的代码,以及将接收内容后的SendMessage替换为PostMessage,可以实现连续发送数据。在ReadFile和GetOverlappedResult的错误处理中,注意对ERROR_IO_PENDING的处理,以支持异步操作。
摘要由CSDN通过智能技术生成

1.注释掉发送部份的清空缓冲区语句就行

void CSerialPort::WriteChar(CSerialPort* port)
{
BOOL bWrite = TRUE;
BOOL bResult = TRUE;


DWORD BytesSent = 0;
ResetEvent(port->m_hWriteEvent);


EnterCriticalSection(&port->m_csCommunicationSync);


// Gain ownership of the critical section


if (bWrite)
{
// Initailize variables
port->m_ov.Offset = 0;
port->m_ov.OffsetHigh = 0;


// Clear buffer, 这里注释就好了.
// PurgeComm(port->m_hComm, PURGE_RXCLEAR | PURGE_TXCLEAR | PURGE_RXABORT | PURGE_TXABORT);



2.如果想在接受收内容后,连续发送

SendMessage 改为PostMessage就好,

void CSerialPort::ReceiveChar(CSerialPort* port, COMSTAT comstat)
{
BOOL  bRead = TRUE; 
BOOL  bResult = TRUE;
DWORD dwError = 0;
DWORD BytesRead = 0;

cserialport 是一个串口通讯库,用于在计算机上与外部设备进行串口通信。当出现连续读卡死的问题时,可能有以下几个原因和解决方法。 首先,可能是由于串口通信设置不正确导致的。可以检查串口的波特率、数据位、停止位、校验位等设置是否与设备的要求一致。如果设置不正确,可以尝试修改设置,重新连接设备进行测试。 其次,可能是由于读卡的过程中出现了死循环或者死锁,导致程序无法继续执行。在使用 cserialport 进行读卡操作时,需要确保在适当的时候停止读卡操作,否则可能会导致死循环。可以检查代码中是否有适当的终止读卡的逻辑,例如在读完一张卡之后停止读卡操作。 另外,可能是由于外部设备的故障或者不稳定性导致的。可以尝试重新连接设备,或者使用其他串口通讯库进行测试,看是否仍然出现连续读卡死的问题。如果是设备本身的问题,可能需要修复或替换设备。 最后,也可能是由于程序中的 bug 或者其他代码逻辑问题导致的。可以检查代码中是否有可能导致程序死锁或死循环的地方,并修复相应的 bug。可以使用调试工具或者添加适当的日志信息来帮助定位问题所在。 总之,当 cserialport 连续读卡死时,可以从串口通信设置、读卡逻辑、设备故障以及代码问题等多个方面进行排查,并根据具体情况采取相应的解决办法。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值