QT信号槽连接方式

我们最常用的connect()函数的原型之一如下:

QMetaObject::Connection QObject::connect(const QObject * sender, const char * signal, const QObject * receiver, const char *

method, Qt::ConnectionType type = Qt::AutoConnection)

最后的ConnectionType是一个缺省的参数,默认为自动连接方式,我们来看一下这个参数有哪些值:

1. AutoConnection

自动连接,默认值。

If the signal is emitted in the thread which the receiving object has affinity then the behavior is the same as the Direct Connection.

Otherwise, the behavior is the same as the Queued Connection.

如果信号的发送者和信号的接受者的对象同属一个线程,那个工作方式与直连方式相同;否则工作方式与排队方式相同。

2. Direct Connection

直接连接。

The slot is invoked immediately, when the signal is emitted. The slot is executed in the emitter's thread, which is not necessarily

the receiver's thread.

当信号发出后,相应的槽函数将立即被调用;

emit语句后的代码将在所有槽函数执行完毕后被执行,信号与槽函数关系类似于函数调用,同步执行

3. Queued Connection

排队方式连接。

The slot is invoked when control returns to the event loop of the receiver's thread. The slot is executed in the receiver's thread.

当信号发出后,排队到信号队列中,需等到接收对象所属线程的事件循环取得控制权时才取得该信号,调用相应的槽函数。

emit语句后的代码将在发出信号后立即被执行,无需等待槽函数执行完毕;

此时信号被塞到信号队列里了,信号与槽函数关系类似于消息通信,异步执行。

4. Blocking Queued Connection

阻塞的排队方式。

The slot is invoked as for the Queued Connection, except the current thread blocks until the slot returns.

Using this type to connect objects in the same thread will cause deadlock.

插槽作为队列连接调用,除非当前线程阻塞,直到插槽返回。

使用此类型连接同一线程中的对象将导致死锁。

5. Unique Connection

The behavior is the same as the Auto Connection, but the connection is made only if it does not duplicate an existing connection. 

Be aware that using direct connections when the sender and receiver live in different threads is unsafe if an event loop is running

in the receiver's thread, for the same reason that calling any function on an object living in another thread is unsafe.

该行为与自动连接相同,但是只有在不复制现有连接的情况下才会进行连接。

请注意,如果事件循环在接收方的线程中运行,那么当发送方和接收方位于不同线程中时使用直接连接是不安全的,这与调用

于另一个线程中的对象上的任何函数都是不安全的道理是一样的。

    // Qt4连接方式,信号发送者,信号,信号接受者,处理函数
    QObject::connect(ui->pushButton,SIGNAL(clicked(bool)),this,SLOT(qT4_slot()));


    // Qt5的新方法,编译会有安全监测
    QObject::connect(ui->pushButton,&QPushButton::clicked,this,&Widget::qT5_slot);


    // Qt5 Lambda表达式,这里需要注意 Lambda表达式是C++ 11 的内容,所以,需要再Pro项目文件中加入 CONFIG += C++ 11
    QObject::connect(ui->pushButton,&QPushButton::clicked,[=](){qDebug()<<"lambda 表达式";});

 

你可能感兴趣的:(QT)