QLocalSocket-QTimer和Lambda

QLocalSocket-QTimer和Lambda,qt,lambda,qlocalsocket,Qt,Lambda,Qlocalsocket,Qt5.7.1上的Lambda和timer有一个奇怪的行为。可能是我弄错了 我用一个插座启动一个连接,并设置一个计时器来检查它是否在一段时间后连接 插座连接的信号将停止计时 然而,在以下实现中,即使调用连接的信号,计时器也不会停止 constructor: m_connectTimeout.setInterval(5000); connect(&m_socket, &QLocalSocket::connected, [&]() { // this is cal

Qt5.7.1上的Lambda和timer有一个奇怪的行为。可能是我弄错了

我用一个插座启动一个连接,并设置一个计时器来检查它是否在一段时间后连接

插座连接的信号将停止计时

然而,在以下实现中,即使调用连接的信号,计时器也不会停止

constructor:

m_connectTimeout.setInterval(5000);

connect(&m_socket, &QLocalSocket::connected, [&]()
{
    // this is called first and should stop the timer.
    m_connectTimeout.stop();
});


connect(&m_connectTimeout, &QTimer::timeout, [&](){
       // this is still called
});
以下是Qt5.7.1和Windows 10上重现问题的最小示例

#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();
}

我还注意到,它并不总是可复制的,而且似乎是随机的。

实际上,代码似乎是有效的,只是连接太快了,在timer.start之前调用timer.stop

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

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

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

m_connectTimeout.stop()是否实际运行?设置断点并查看它是否运行请尝试提供一个断点。我想不出为什么
m_connectTimeout.stop()
没有停止计时器(您真的确定它是先调用的吗?)。这是一个可以工作但不会重现问题的方法。@Victor,是的,它确实在运行,我实际上在那里有调试输出。@Mike完成并edited@Mike刚才对不起,没想到你会这么快是的,这就是问题所在,我正在写答案。
connected()
信号从
connectToServer()
内发出,计时器在插槽中停止后启动。
m_timer.start();
m_socketClient.connectToServer(PIPENAME, QLocalSocket::ReadWrite);