我有一个 QthreadPool 可以同时连接多达 5 个串行设备。每个串行设备定义为:
struct serialDevice
{
std::shared_ptr<QSerialPort> port;
QByteArray portData;
};
在 GUI 中,单击按钮后,我调用串行设备管理器serialManager->startAcquisition(portNames)
,如下所示:
#include "serialmanager.h"
serialManager::serialManager(QObject *parent) : QObject(parent)
{
pool = new QThreadPool();
pool->setMaxThreadCount(5);
}
void serialManager::startAcquisition(QStringList pNames)
{
foreach (QString port, pNames)
{
this->stablishConnection(port);
}
}
void serialManager::stablishConnection(QString pName)
{
ComPort *workerPort = new ComPort();
workerPort->setAutoDelete(true);
workerPort->setName(pName);
connect(this, SIGNAL(finished()), workerPort, SLOT(onTaskeFinished()));
pool->start(workerPort);
}
连接设备后,我会轮询设备。调用停止函数时线程终止。我希望readyRead()
正在发出信号,以便填充sensor->portData
:
#include "serialmanager.h"
#include <QEventLoop>
ComPort::ComPort(QObject *parent) : QObject(parent)
{
}
void ComPort::run()
{
QEventLoop loop;
connect(this, SIGNAL(finished()), &loop, SLOT(quit()));
sensor = std::make_shared<serialDevice> ();
sensor->port = std::make_shared<QSerialPort> ();
sensor->port->setPortName(this->portName);
sensor->port->setBaudRate(QSerialPort::Baud19200);
sensor->port->setDataBits(QSerialPort::Data8);
sensor->port->setFlowControl(QSerialPort::NoFlowControl);
sensor->port->setParity(QSerialPort::NoParity);
sensor->port->setStopBits(QSerialPort::OneStop);
QString strPort;
if (sensor->port->open(QIODevice::ReadWrite) == true)
{
connect(sensor->port.get(), SIGNAL(error(QSerialPort::SerialPortError)), this, SLOT(onErrorReceived()));
connect(sensor->port.get(), SIGNAL(readyRead()), this, SLOT(onReadyRead()));
}
else
{
strPort = "> " + sensor->port->portName() + " device is not streaming: " + sensor->port->errorString();
emit this->newMsgAvailable(strPort);
emit this->finished();
}
loop.exec();
}
void ComPort::onReadyRead()
{
QByteArray bytes = this->sensor->port->readAll();
this->sensor->portData.append(bytes);
}
void ComPort::onTaskeFinished()
{
QString strPort = "> Finished streaming at " + sensor->port->portName();
emit newMsgAvailable(strPort);
emit this->finished();
}
void ComPort::onErrorReceived()
{
QString strPort = "> Data stream on " + sensor->port->portName() + " failed: " + sensor->port->errorString();
emit newMsgAvailable(strPort);
}
问题定义:
没有readyRead()
发出信号。我在这里读过,要处理 a 中的事件QRunnable
,线程需要有自己的事件循环。所以我QEventLoop loop
把Run()
每个ComPort
. 现在readyRead()
被触发,我从每个端口接收数据一段时间,然后突然之间应用程序崩溃并出现分段错误:
0 VerifierDisableFaultInjectionExclusionRange C:\WINDOWS\syswow64\verifier.dll 0x53457378
1 VerifierDisableFaultInjectionExclusionRange C:\WINDOWS\syswow64\verifier.dll 0x53457495
2 VerifierDisableFaultInjectionExclusionRange C:\WINDOWS\syswow64\verifier.dll 0x5345b651
3 VerifierCheckPageHeapAllocation C:\WINDOWS\syswow64\verifier.dll 0x53460b12
4 ?? C:\WINDOWS\SysWOW64\vfbasics.dll 0x533d179f
5 msvcrt!free C:\WINDOWS\SysWOW64\msvcrt.dll 0x7509b0f9
6 ?? 0x19120000
7 ?? C:\WINDOWS\SysWOW64\vfbasics.dll 0x533d26a5
8 QArrayData::deallocate 130
9 QTypedArrayData<char>::deallocate 234 0x6b9cbcfd
10 QByteArray::resize 1448 0x6b79bc23
11 QRingBuffer::append 383 0x645893ae
12 QSerialPortPrivate::_q_completeAsyncRead 529 0x6458523f
13 QSerialPort::qt_static_metacall 353 0x64582dae
14 QMetaObject::activate 3681 0x6b955027
15 QMetaObject::activate 3547 0x6b95498c
16 QWinEventNotifier::activated 134 0x6b9ad529
17 QWinEventNotifier::event 241 0x6b976af1
18 QApplicationPrivate::notify_helper 3499 0xf33df61
19 QApplication::notify 2952 0xf33ba13
20 QCoreApplication::notifyInternal 935 0x6b929eee
... <More>