博客
关于我
Qt信号和槽--对象之间的通信
阅读量:166 次
发布时间:2019-02-28

本文共 1367 字,大约阅读时间需要 4 分钟。

Qt中最明显的特点就是采用信号槽机制,使得对象之间可以相互通信,传递消息,在前台界面开发中应用尤其广泛。

关联两个对象,要使用conncet函数,如下,sender发送一个signal信号,receiver就会执行method方法

QMetaObject::Connection QObject::connect(const QObject * sender, const char * signal, const \QObject * receiver, const char * method, Qt::ConnectionType type = Qt::AutoConnection)

举一个例子

头文件

#ifndef SIGNALSLOTDEMO_H#define SIGNALSLOTDEMO_H#include 
class SignalSlotDemo : public QObject{ Q_OBJECTpublic: explicit SignalSlotDemo(QObject *parent = 0); int getValue();signals: void changedValue(int newValue);public slots: void setValue(int value);private: int value;};#endif // SIGNALSLOTDEMO_H

源文件

#include "signalslotdemo.h"#include 
using namespace std;SignalSlotDemo::SignalSlotDemo(QObject *parent) : QObject(parent),value(){}int SignalSlotDemo::getValue(){ return this->value;}void SignalSlotDemo::setValue(int value){ this->value = value; emit changedValue(this->value);}

测试文件

#include 
#include
using namespace std;#include "signalslotdemo.h"int main(int argc, char *argv[]){ QCoreApplication a(argc, argv); SignalSlotDemo demo1; SignalSlotDemo demo2; QObject::connect(&demo1, SIGNAL(changedValue(int)), &demo2, SLOT(setValue(int))); demo1.setValue(200); cout<
<

demo1 在调用自己的成员方法setValue的时候,会发射一个changedValue信号(携带变量value),这时候demo2的setValue就会被调用了

转载地址:http://uzfc.baihongyu.com/

你可能感兴趣的文章
Mysql join原理
查看>>
MySQL Join算法与调优白皮书(二)
查看>>
Mysql order by与limit混用陷阱
查看>>
Mysql order by与limit混用陷阱
查看>>
mysql order by多个字段排序
查看>>
MySQL Order By实现原理分析和Filesort优化
查看>>
mysql problems
查看>>
mysql replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
mysql replace用法
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql server has gone away
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
MYSQL sql语句针对数据记录时间范围查询的效率对比
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>