我对Qt中的线程的了解相当有限,我现在遇到一个似乎与线程有关的问题。我正在使用QextSerialPort进行uart通信。我的串行通信类看起来像这样(剥离到最小):
SerialIO::SerialIO() {
port = new QextSerialPort("/dev/ttymxc1");
connect(port, SIGNAL(readyRead()), this, SLOT(onDataAvailable()));
port->setQueryMode(QextSerialPort::EventDriven);
port->open(QIODevice::ReadWrite | QIODevice::Unbuffered);
port->setBaudRate(BAUD115200);
port->setFlowControl(FLOW_OFF);
port->setParity(PAR_NONE);
port->setDataBits(DATA_8);
port->setStopBits(STOP_1);
}
void SerialIO::initialize() {
// do something
// wait for 15 s
// do something else
}
void SerialIO::onDataAvailable() {
// do something useful
}
问题是在initialize()
方法中等待15秒而不阻塞串行输入。我试过了
QThread::sleep(15)
甚至
QTime time;
time.start();
while(time.elapsed() < 15000); // evil busy wait
但是在两次尝试中,我都停止了获取串行数据(在这15秒内不再调用onDataAvailable
)。这样做的正确方法是什么?
答案 0 :(得分:4)
这种方法怎么样:
void SerialIO::initialize()
{
// do something
// wait for 15 s
QTimer::singleShot(15000, this, SLOT(onTimer()));
}
void SerialIO::onDataAvailable()
{
// do something useful
}
void SerialIO::onTimer()
{
// do something else
}
它不会阻止事件,您将调用onDataAvailable()
个插槽。
答案 1 :(得分:1)
在不创建额外功能的情况下等待的另一种方法:
void SerialIO::initialize() {
// Code here
QEventLoop loop;
QTimer::singleShot(15000, &loop, SLOT(quit()));
loop.exec();
// Code here, executed after 15s
}
注意:如果某些内容删除serialIO
deleteLater
(处理等待期间收到的某些事件/信号,可能来自您的串行输入),您将被删除且无效this
循环退出后。如果这可能是你的应用程序的真实情况,最好在@ vahancho的答案之后使用一个单独的插槽来执行。