坑描述:
connect(&m_webSocket, &QWebSocket::textMessageReceived, this, &BWebsocket::onTextMessageReceived);
和主机通过websocket通信。接收主机发的指令有时导致重复接收。信号发送者和接受者同一线程。onTextMessageReceived函数里有逻辑处理,特定数据处理繁杂导致该槽运行较旧。
例如:
主机发送的第一条数据为长度100,内容“ABCD*1234”。
主机发送的第二条数据长度30,内容"9999";
两条数据主机几乎同时发送,出现bug现象为:
主机端、客户端抓包正常,但是onTextMessageReceived打印出来的结果是,长度130,数据内容为“ABCD*12349999”。
下图为:实际场景数据。
解决方式:
connect(&m_webSocket, &QWebSocket::textMessageReceived, this, &BWebsocket::onTextMessageReceived,Qt::QueuedConnection);