大家好!
我在 Qt 5.8 上通过QSerialBus
库实现了我的ModBus实现问题。
问题 - 当我尝试高速读取离散输入列表时,程序会发现内存泄漏 - 大约每秒 300-350Kb 。
所以,这里导致泄漏的函数代码:
void ModBus::queue()
{
if(!_readList.isEmpty())
{
if(!checkState())
{
_readList.clear();
_curPos = DiscInputPos::Full;
queue();
return;
}
QModbusDataUnit readData = QModbusDataUnit(QModbusDataUnit::DiscreteInputs, _readList.first(), 1);
if(auto *reply = _client->sendReadRequest(readData, _serverNum))
{
if(!reply->isFinished())
{
connect(reply, &QModbusReply::errorOccurred, [=] (QModbusDevice::Error e)
{
reply->deleteLater();
if(e == QModbusDevice::TimeoutError)
{
_readList.clear();
_curPos = DiscInputPos::Full;
stop();
start();
queue();
}
});
connect(reply, &QModbusReply::finished, this, [=]
{
if(reply->error() == QModbusDevice::NoError)
{
if(reply->result().valueCount() > 0)
{
_curPos = (DiscInputPos) reply->result().value(0);
if(_curPos == DiscInputPos::Clear)
_readList.removeFirst();
else
_readList.clear();
}
}
else
{
_readList.clear();
_curPos = DiscInputPos::Full;
}
reply->deleteLater();
queue();
});
}
else
delete reply;
}
else
{
delete reply;
_readList.clear();
_curPos = DiscInputPos::Full;
queue();
}
}
else
{
emit sendReadResult(_curPos);
_curPos = DiscInputPos::Full;
}
}
_client
- QModbusTcpClient
bool checkState()
- 除非检查连接状态,否则没有什么特别之处。
最大_readList
尺寸 4 。
如果我用_client->sendReadRequest
评论部分代码 - 一切都没有任何泄漏。任何人都可以解释 - 它可以是什么?
提前致谢!
答案 0 :(得分:0)
我通过计时器在 0.5秒(较少导致泄漏)解决了这个问题,从类中检查来自9223372036854775807
类的答案。仍有泄漏,但远远少于此。如果 1秒 - 没有泄漏。
ModBus
但我认为这是一个糟糕的解决方案。
<强> UPD。强>
Qt社区solved这样的问题:
connect(d, &ModBus::sendReadResult, this, &StatusesWorker::getRead);
void StatusesWorker::getRead(DiscInputPos s)
{
bool cleared = (s == DiscInputPos::Clear);
if(!cleared)
emit badSensors();
else
emit clearSensors();
QTimer::singleShot(500, [=] { checkSensor(id); });
}
}
它没有泄漏就能更快地完成工作。当然,connect(reply, &QModbusReply::destroyed, [this] { QTimer::singleShot(60, [this] { queue(); }); });
现在没有计时器。