在某些场景下,我们需要临时暂停信号的传递,而不是永久性的断开连接。这时,信号的阻塞就派上用场了。
'blockSignals’函数是QObject类的一部分,它接受一个布尔值参数,true表示阻塞信号,false表示解除阻塞。这使得我们可以在需要的时候暂时停止某些信号的处理。
例如:
MyEmitter emitter;
// 阻塞信号
emitter.blockSignals(true);
// 发射信号,但不触发槽函数
emit emitter.mySignal();
// 解除信号阻塞
emitter.blockSignals(false);
// 发射信号,触发槽函数
emit emitter.mySignal();
在运行时,我们可能需要动态地断开信号与槽的连接,以便更灵活地管理事件处理。
‘disconnect’函数允许我们在运行时断开信号与槽的连接,提供了对连接的动态管理。
例如:
MyEmitter emitter;
MyReceiver receiver;
// 连接信号与槽
QMetaObject::Connection connection = QObject::connect(&emitter, &MyEmitter::mySignal, &receiver, &MyReceiver::mySlot);
// 发射信号,触发槽函数
emit emitter.mySignal();
// 断开连接
QObject::disconnect(connection);
// 发射信号,不再触发槽函数
emit emitter.mySignal();
为了更好地理解信号的阻塞和断开的实际应用,让我们看一个场景应用的示例:一个即时消息应用。
示例:
#include
#include
/**
* @brief 消息发送者
*/
class MessageSender : public QObject
{
Q_OBJECT
signals:
void sendMessage(QString message);
};
/**
* @brief 消息接收者
*/
class MessageReceiver : public QObject
{
Q_OBJECT
public slots:
void showMessage(QString message) {
qDebug() << "Received message: " << message;
}
};
int main(int argc, char *argv[])
{
QCoreApplication app(argc, argv);
MessageSender sender;
MessageReceiver receiver;
// 连接信号与槽
QMetaObject::Connection connection = QObject::connect(&sender, &MessageSender::sendMessage, &receiver, &MessageReceiver::showMessage);
// 模拟消息发送
emit sender.sendMessage("Hello!");
// 阻塞消息发送
sender.blockSignals(true);
// 模拟消息发送,但不触发槽函数
emit sender.sendMessage("Blocked!");
// 解除消息阻塞
sender.blockSignals(false);
// 模拟消息发送,触发槽函数
emit sender.sendMessage("World!");
// 断开连接,不再接收消息
QObject::disconnect(connection);
// 模拟消息发送,不再触发槽函数
emit sender.sendMessage("Disconnected!");
return app.exec();
}
#include "main.moc"
最终将只打印 “Hello!” 和 “World!”,这就达到了我们想要的结果。