Poco版信号槽

#include "Poco/BasicEvent.h"
#include "Poco/Delegate.h"
#include <iostream>

using Poco::BasicEvent;
using Poco::Delegate;
#include <typeinfo>
class A
{
public:
    BasicEvent<std::string> theEvent;
    void sentToB(std::string message)
    {
        theEvent(this,message);
    }
    void getFromB(const void* pSender,std::string &message)
    {
        std::cout<<"cur class is:"<<typeid(A).name()<<std::endl;
        std::cout<<"B says:"<<message<<std::endl;
    }
};
class B
{
public:
    BasicEvent<std::string> theEvent;
    void sentToA(std::string message)
    {
        theEvent(this,message);
    }
    void getFromA(const void* pSender,std::string &message)
    {
        std::cout<<"cur class is:"<<typeid(B).name()<<std::endl;
        std::cout<<"A says:"<<message<<std::endl;
    }
};
int main(int argc,char ** argv)
{
    A aDemo;
    B bDemo;

aDemo.theEvent += Delegate<B,std::string>(&bDemo,&B::getFromA);
    bDemo.theEvent += Delegate<A,std::string>(&aDemo,&A::getFromB);

aDemo.sentToB("bendan");
    bDemo.sentToA("zhen sha");
    return 0;
}
-lPocoFoundation

时间: 2024-10-29 19:08:06

Poco版信号槽的相关文章

信号槽库:sigslot.h和sigc++使用

用qt的知道,qt有方便简单的信号槽机制,但需要专门的qt工具处理. 如果想直接使信号槽就可以使用sigslot库,或者sigc++库,或者boost中的signals,这里介绍sigslot和sigc++库. sigslot.h:只有一个头文件,使用简单方便. sigc++:包含文件多,但功能更强大. sigslot库 官方地址 http://sigslot.sourceforge.net/ 在vs2013中使用 包含头文件 #include "sigslot.h" 1 1 改动:

Qt 编程指南 3 信号槽

https://qtguide.ustclug.org/ 忽略自动补全报的错 在图形界面修改过后,自动补全未必及时读取新加入的控件的信息 1 代码自写 1 在主窗口头文件Qt_tset1.h里声明这个函数FoodIsComing() 2 在主窗口函数文件Qt_tset1.cpp里实现这个函数体FoodIsComing() 3 创建链接执行函数.控件动作触发事件,然后调用函数执行 例如: 按键 的 单击动作 触发 主窗体 中的    FoodIsComing() 函数,并执行. 2 图形 所谓信号

QT子线程与主线程的信号槽通信

最近用QT做一个服务器,众所周知,QT的主线程必须保持畅通,才能刷新UI.所以,网络通信端采用新开线程的方式.在涉及到使用子线程更新Ui上的控件时遇到了点儿麻烦.网上提供了很多同一线程不同类间采用信号槽通信的方式,但是并不完全适合线程间的信号槽通信,这主要体现在自定义消息的传递上. 首先我们看看一般的方式: testthread.h 文件 #ifndef TESTTHREAD_H #define TESTTHREAD_H #include <QThread> #include "ms

PyQt5 笔记(05):信号/槽

PyQt 的很多类都内置了信号和槽.下图是 Qt 官方文档对 QThread 类中包含的信号/槽的描述: 一.信号/槽 都是内置的 请看一个最简单的程序: 按钮点击后,窗口关闭 代码: class Test(QDialog): def __init__(self, parent=None): super().__init__(parent) btn = QPushButton('关闭', self) btn.clicked.connect(self.close) # ① 对语句①的说明: 信号

在非UI线程中更改UI(Delphi使用隐藏窗口来处理,QT使用信号槽)

在Delphi里我记得是使用TThread.Synchronize(TThreadMethod),原理是利用了一个隐藏窗口来处理. 在QT Debug模式一下,碰到了同样的问题,显示错误: cannot send events to objects owned by a different thread 解决方案是使用信号槽,就是在线程里不断的发信号,UI线程的槽函数不断的接受信号并做处理: So as a solution I would propose the following: Defi

用ISO C++实现自己的信号槽(Qt另类学习)

qtc++objectsignalclassstring 目录(?)[-] Qt信号与槽 引入元对象系统 建立信号槽链接 信号的激活 槽的调用 全家福 零零散散写在后面 Q_OBJECT Connection 其他 有网友抱怨: 哪个大牛能帮帮我,讲解一下信号槽机制的底层实现? 不要那种源码的解析,只要清楚的讲讲是怎么发送信号,怎么去选择相应的槽,再做出反应.也就是类似于一个信号槽的相应流程...求解啊!!! 看了源码,真的是一头雾水...撞墙的心都有了~~~~ 本文使用 ISO C++ 一步一

猜测:信号槽的本质是使用Windows的自定义消息来实现的

在不断执行: void MyTool::DeleteAllFiles(){ for (i = 0; i <= n - 1; i++) { // do something }}在for循环没有执行完毕的情况下,外部给这个类发信号,根本接受不到信号.就非得这样写: void MyTool::DeleteAllFiles(){ for (i = 0; i <= n - 1; i++) { QApplication::processEvents(); // do something }}或者:void

Qt connect parent widget 连接父控件的信号槽

Qt中的信号槽系统是不同类中间传递数据的神器,如果连接父子空间之间的信号槽很重要,在父类中实例化子类的时候一定要注意将父类连上,不然信号槽无法使用,比如若子类是个对话框Dialog类,一定不要忘了加this QtClass *qc = new QtClass(this); qc->exec(); 然后如果需要连接到父控件的槽函数,只需在子类的构造函数中加一句: connect(this, SIGNAL(signal()), parentWidget(), SLOT(slot()));

信号槽 与事件区别

转自网络 仔细来看,事件与信号其实并无多大差别,从我们对其需求上来说,都只要能注册事件或信号响应函数,在事件或信号产生时能够被通知到即可.但有一项区别在 于,事件处理函数的返回值是有意义的,我们要根据这个返回值来确定是否还要继续事件的处理,比如在QT中,事件处理函数如果返回true,则这个事件处理 已完成,QApplication会接着处理下一个事件,而如果返回false,那么事件分派函数会继续向上寻找下一个可以处理该事件的注册方法.信号处 理函数的返回值对信号分派器来说是无意义的. 另外还有一