Qt信号槽机制与事件机制的联系

本文深入探讨了Qt中信号槽机制的实现原理,特别是当连接类型为Qt::QueuedConnection时,信号是如何在线程间安全传递并触发槽函数的。通过对源代码的详细分析,解释了queued_activate函数的作用及其实现细节。
摘要由CSDN通过智能技术生成

http://blog.csdn.net/tingsking18/article/details/5157811


版权声明

本文为原创作品,请尊重作者的劳动成果。转载必须保持文章完整性,并以超链接形式注明原始作者“ tingsking18 ”和 主站点 地址,方便其他朋友提问和指正。 

QT源码解析(一) QT创建窗口程序、消息循环和WinMain函数

QT源码解析(二)深入剖析QT元对象系统和信号槽机制

QT源码解析(三)深入剖析QT元对象系统和信号槽机制(续)

QT源码解析(四)剖析Qt的事件机制原理

QT源码解析(五)QLibrary跨平台调用动态库的实现

QT源码解析(六)Qt信号槽机制与事件机制的联系

QT源码解析(七)Qt创建窗体的过程

QT源码解析(八)Qt是如何处理windows消息的

QT源码解析(九)解析QDateTime 

 

 

 

QT源码解析(三)深入剖析QT元对象系统和信号槽机制(续)文章中遗留了一个问题,就是当signal和slot的连接为Qt::QueuedConnection,这时候这个连接是怎么分发处理的。下面就结合一下Qt的源

代码来分析一下。

  1. if ((c->connectionType == Qt::AutoConnection  
  2.      && (currentThreadData != sender->d_func()->threadData  
  3.          || receiver->d_func()->threadData != sender->d_func()->threadData))  
  4.     || (c->connectionType == Qt::QueuedConnection)) {  
  5.     queued_activate(sender, signal, *c, argv);  
  6.     continue;  
  7. else if (c->connectionType == Qt::BlockingQueuedConnection) {  
  8.     blocking_activate(sender, signal, *c, argv);  
  9.     continue;  
  10. }  

这段代码的意思是:当前connectionType为Qt::AutoConnection并且,signal和slot不在一个线程或者是signal和不再当前线程中;或者是c->connectionType为 Qt::QueuedConnection这时候调用函数
queued_activate,如果c->connectionType 为Qt::BlockingQueuedConnection则调用函数blocking_activate
我们当queued_activate和blocking_activate一样就可以了。


queued_activate函数很简单,就是对参数转换一下,然后调用   
QCoreApplication::postEvent(c.receiver, new QMetaCallEvent(c.method,sender,signal,nargs,types,args,semaphore));
注意: postEvent第二个参数是QMetaCallEvent。这样这个signal-slot的connection就发送到receiver的消息队列中去了。
接下来消息队列如何处理QMetaCallEvent,请参考 QT源码解析(四)剖析Qt的事件机制原理


后记:通过这种方法Qt实现了跨线程的signal-slot传递,并且这种signal-slot机制的传递是利用消息队列,所以说是线程安全的。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值