日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

QT Core | 信号槽03 - 自定义信号与槽

發布時間:2025/3/15 c/c++ 55 豆豆
生活随笔 收集整理的這篇文章主要介紹了 QT Core | 信号槽03 - 自定义信号与槽 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • 一、前言
  • 二、新建一個QT控制臺項目
    • 2.1、New File or Project
    • 2.2、Project Location
    • 2.3、Define Build System
    • 2.4、Kit Selection
    • 2.5、Project Application
    • 2.6、生成的項目
  • 三、創建類
    • 3.1、創建Newspaper類
    • 3.2、創建Reader類
  • 四、編寫代碼
    • 4.0、pro文件
    • 4.1、newspaper.h
    • 4.2、newspaper.cpp
    • 4.3、reader.h
    • 4.4、reader.cpp
    • 4.5、main.cpp
  • 五、Debug
  • 六、用一個信號同步(觸發)兩個槽
    • 6.1、reader.h
    • 6.2、reader.cpp
    • 6.3、main.cpp
    • 6.4、控制臺

一、前言


記住,信號與槽本質都是返回類型為void的函數。
QT提供的信號與槽,是QT的核心功能之一。它們跟QT的GUI沒有關系,所以編寫沒有GUI的QT應用程序也是可以使用QT的信號與槽的。值得注意的是,使用QT編寫漂亮且模塊化的應用程序必須要使用信號與槽。
只要用戶編寫的類繼承QObject類,就能使用信號與槽的功能。QT的signal(信號)與slot(槽)本質就是一個函數,且不需要返回值,意識到這一點非常重要。從下圖可以看到,Object1的signal1可以同步(觸發)Object2的slot1與slot2。Object1的signal2可以同步(觸發)Object4的slot1。所以,QT的信號與槽有利于程序的模塊化。

請同學們務必學習豆子的博客上的《QT學習之路2(5)自定義信號槽》,才能看懂以下的內容。博客地址:https://www.devbean.net/2012/08/qt-study-road-2-custom-signal-slot/
我的QT版本:

QT工程:
鏈接:https://pan.baidu.com/s/1lqoq0XhUgE1De8Ok1FPTHQ
提取碼:s6yp

二、新建一個QT控制臺項目


2.1、New File or Project

2.2、Project Location

2.3、Define Build System

2.4、Kit Selection

2.5、Project Application

2.6、生成的項目

三、創建類


3.1、創建Newspaper類





3.2、創建Reader類

以同樣的方式創建Reader類

四、編寫代碼


4.0、pro文件

QT創建的項目默認是C++11版本,目前大部分的C++教程都是使用C++14版本,所以我決定使用C++14版本。值得注意的是,C++版本越高并不代表越好,追求穩定才是硬道理。

4.1、newspaper.h

#ifndef NEWSPAPER_H #define NEWSPAPER_H#include <QObject>class Newspaper : public QObject {Q_OBJECT public:explicit Newspaper(QObject *parent = nullptr);Newspaper(const QString& name);void send() const; /* 用于發送已有的信號 */signals:/* 1、信號就是一個一個函數名,信號不需要返回變量,所以都是void.* 2、信號的函數不需要實現,因為QT的moc幫我們實現好了.* 3、信號的內容是什么?其實就是函數的入口參數.*/void newPaper(const QString& name) const; /* 聲明一個信號(newPaper) */public slots:private:QString m_name;};#endif // NEWSPAPER_H

4.2、newspaper.cpp

#include "newspaper.h"Newspaper::Newspaper(QObject *parent) : QObject(parent) {}Newspaper::Newspaper(const QString& name):m_name(name) {}/* 該函數用于發送已經定義好的信號 */ void Newspaper::send() const {emit newPaper(m_name); //發送newPaper信號,該信號的內容是m_name }

4.3、reader.h

#ifndef READER_H #define READER_H#include <QObject> #include <QDebug> class Reader : public QObject {Q_OBJECT public:explicit Reader(QObject *parent = nullptr);signals:public slots:void receiveNewspaper(const QString& name) const; };#endif // READER_H

4.4、reader.cpp

#include "reader.h"Reader::Reader(QObject *parent) : QObject(parent) {}void Reader::receiveNewspaper(const QString& name) const {qDebug() << "Receives Newspaper: " << name; }

4.5、main.cpp

#include <QCoreApplication>#include "newspaper.h" #include "reader.h"int main(int argc, char *argv[]) {QCoreApplication a(argc, argv);Newspaper newspaper("Newspaper A"); /* 創建newspaper對象 */Reader reader; /* 創建reader對象 *//* 建立信號與槽 */QObject::connect(&newspaper,&Newspaper::newPaper,&reader, &Reader::receiveNewspaper);newspaper.send(); /* 調用信號,并觸發對應的槽 */return a.exec(); }

五、Debug


編譯,運行。控制臺輸出一條字符串。

返回上面的代碼可以了解到,newspaper對象不具備打印字符串到控制臺的功能,只有reader對象才能往控制臺輸出字符串。所以,上面的字符串肯定是reader對象得槽函數打印出來的。

六、用一個信號同步(觸發)兩個槽


上面的例子是1個信號同步一個槽,根據官方的介紹,1個信號可以同步多個槽的。所以,這里嘗試增加多一個槽。
信號的代碼不需要修改,所以newspaper.cpp與newspaper.h不用修改(Newspaper類不用修改)。槽的代碼需要修改一下,因為要給reader增加一個類屬性my_name。

6.1、reader.h

#ifndef READER_H #define READER_H#include <QObject> #include <QDebug> class Reader : public QObject {Q_OBJECT public:explicit Reader(QObject *parent = nullptr);Reader(const QString& name); //增加一個構造函數signals:public slots:void receiveNewspaper(const QString& name) const ;private:QString my_name; //增加名字 };#endif // READER_H

6.2、reader.cpp

#include "reader.h"Reader::Reader(QObject *parent) : QObject(parent) {}Reader::Reader(const QString& name):my_name(name) {}void Reader::receiveNewspaper(const QString& name) const {qDebug() <<"I am" << this->my_name << "Receives Newspaper: " << name; }

6.3、main.cpp

#include <QCoreApplication> #include "newspaper.h" #include "reader.h"int main(int argc, char *argv[]) {QCoreApplication a(argc, argv);Newspaper newspaper("Newspaper A"); /* 創建newspaper對象 */Reader reader_A("reader_A"); /* 創建reader_A對象 */Reader reader_B("reader_B"); /* 創建reader_B對象 *//* 建立信號與槽 */QObject::connect(&newspaper,&Newspaper::newPaper,&reader_A, &Reader::receiveNewspaper);/* 建立信號與槽 */QObject::connect(&newspaper,&Newspaper::newPaper,&reader_B, &Reader::receiveNewspaper);newspaper.send(); /* 調用信號,并觸發對應的槽 */return a.exec(); }

6.4、控制臺

總結

以上是生活随笔為你收集整理的QT Core | 信号槽03 - 自定义信号与槽的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。