在Qt等了几秒钟

时间:2013-12-11 15:45:59

标签: multithreading qt qextserialport

我对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)。这样做的正确方法是什么?

2 个答案:

答案 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的答案之后使用一个单独的插槽来执行。