QLocalSocket - QTimer和Lambda

时间:2017-01-17 11:08:56

标签: qt lambda qlocalsocket

我在Qt 5.7.1上对Lambda和计时器有一种奇怪的行为。可能是我的错误。

我开始与套接字建立连接并设置一个计时器,以便在一段时间后检查它是否已连接。

插座连接的信号将停止时间。

但是,通过以下实现,即使调用连接的信号,定时器也不会停止。

#include <QtCore>
#include <QtNetwork>

#define PIPENAME "testbug"

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    QTimer timer;
    QLocalSocket socketClient, *socketServer;
    QLocalServer server;
    timer.setInterval(2000);


    QObject::connect(&timer, &QTimer::timeout, [&]
    {
        qDebug() << "client connection timed out";
        timer.stop();
    });

    QObject::connect(&socketClient, &QLocalSocket::connected, [&]
    {
        qDebug() << "client connected";
        timer.stop();
    });

    QObject::connect(&server, &QLocalServer::newConnection, [&]
    {
        qDebug() << "server got connection";
        socketServer = server.nextPendingConnection();
    });

    server.setSocketOptions(QLocalServer::WorldAccessOption);
    server.listen(PIPENAME);

    qDebug() << "client connecting. . .";
    socketClient.connectToServer(PIPENAME, QLocalSocket::ReadWrite);
    timer.start();

    return a.exec();
}

以下是Qt5.7.1和Windows 10上可重现问题的最小示例。

client connecting. . .
client connected
server got connection
client connection timed out

计划的输出:

ContentPreview

我也注意到它并不总是可以复制,而且似乎有些随机。

1 个答案:

答案 0 :(得分:1)

实际上看起来代码是有效的,只是连接速度很快,在timer.start之前调用了timer.stop。

在调用connect to server之前启动计时器似乎解决了问题

m_timer.start();
m_socketClient.connectToServer(PIPENAME, QLocalSocket::ReadWrite);

这意味着connectToServer在后台对事件循环进行一些调用,允许调用插槽,甚至在下一行执行之前。