博客
关于我
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 - 4种基本索引、聚簇索引和非聚索引、索引失效情况、SQL 优化
查看>>
MySQL - ERROR 1406
查看>>
mysql - 视图
查看>>
MySQL - 解读MySQL事务与锁机制
查看>>
mysql 1264_关于mysql 出现 1264 Out of range value for column 错误的解决办法
查看>>
mysql 1593_Linux高可用(HA)之MySQL主从复制中出现1593错误码的低级错误
查看>>
mysql ansi nulls_SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON 什么意思
查看>>
MySQL Binlog 日志监听与 Spring 集成实战
查看>>
multi-angle cosine and sines
查看>>
Mysql Can't connect to MySQL server
查看>>
mysql case when 乱码_Mysql CASE WHEN 用法
查看>>
Multicast1
查看>>
MySQL Cluster 7.0.36 发布
查看>>
Multimodal Unsupervised Image-to-Image Translation多通道无监督图像翻译
查看>>
multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
查看>>
mysql cmake 报错,MySQL云服务器应用及cmake报错解决办法
查看>>
Multiple websites on single instance of IIS
查看>>
mysql CONCAT()函数拼接有NULL
查看>>
multiprocessing.Manager 嵌套共享对象不适用于队列
查看>>
multiprocessing.pool.map 和带有两个参数的函数
查看>>