QT信号与槽实现方式

时间:2024-03-15 07:25:33
#include "widget.h"
#include "ui_widget.h"
//widget.cpp
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    //连接槽  ,触发对象和接收都是自己
    QObject::connect(this ,SIGNAL(mysignal()) ,this ,SLOT(myslot()));
    QObject::connect( this ,SIGNAL(mysignalparams(int)) ,this ,SLOT(myslotparams(int)) );
    emit mysignal();        //触发信号
    emit mysignalparams(999);   //触发带参数的信号
}

Widget::~Widget()
{
    delete ui;
}

void Widget::myslot()     //槽函数
{
    std::cout << "myslot" << std::endl;
}

void Widget::myslotparams(int value)
{
    std::cout << "myslotparams ," << value << std::endl;
    qDebug() << "This is value = " << value;
}

//widget.h
#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <iostream>
#include <QDebug>

QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = nullptr);
    ~Widget();

signals:            //自定义信号
    void mysignal();
    void mysignalparams(int value);

public slots:       //自定义槽
    void myslot();
    void myslotparams(int value);

private:
    Ui::Widget *ui;
};
#endif // WIDGET_H

       执行结果

5.2、例2

        创建两个类,比如SenderReceiverSender类将发出信号,而Receiver类将接收并处理这个信号。

// Sender.h  
#ifndef SENDER_H  
#define SENDER_H  
  
#include <QObject>  
  
class Sender : public QObject {  
    Q_OBJECT  
public:  
    explicit Sender(QObject *parent = nullptr);  
  
signals:      
    void mySignal();      //信号
  
public slots:  
    void emitSignal();  
};  
  
#endif // SENDER_H
// Sender.cpp  
#include "Sender.h"  
  
Sender::Sender(QObject *parent) : QObject(parent) {  
}  
  
void Sender::emitSignal() {  
    emit mySignal();          //发送信号
}
// Receiver.h  
#ifndef RECEIVER_H  
#define RECEIVER_H  
  
#include <QObject>  
#include <QDebug>  
  
class Receiver : public QObject {  
    Q_OBJECT  
public:  
    explicit Receiver(QObject *parent = nullptr);  
  
public slots:  
    void handleSignal();      //槽函数
};  
  
#endif // RECEIVER_H
// Receiver.cpp  
#include "Receiver.h"  
  
Receiver::Receiver(QObject *parent) : QObject(parent) {  
}  
  
void Receiver::handleSignal() {  
    qDebug() << "Signal received!";  //槽函数
}
// main.cpp  
#include <QCoreApplication>  
#include "Sender.h"  
#include "Receiver.h"  
  
int main(int argc, char *argv[]) {  
    QCoreApplication a(argc, argv);  
  
    Sender sender;  
    Receiver receiver;  
  
    //连接信号与槽
    QObject::connect(&sender, &Sender::mySignal, &receiver, &Receiver::handleSignal);  
  
    sender.emitSignal(); // 调用函数发送信号
  
    return a.exec();  
}

6、QDebug()

        QDebug 是 Qt 框架中用于输出调试信息的一个类。它提供了一种方便的方式来输出文本到标准输出(通 常是控制台),这对于调试 Qt 应用程序非常有用。 QDebug 类可以与 Qt 的信号和槽机制一起使用,使 得在响应各种事件时能够输出有用的调试信息。
        使用 QDebug 的一个典型方式是通过 qDebug() 函数,它返回一个 QDebug 对象。然后,可以使用流操 作符 << 来输出各种数据类型。例如:
qDebug() << "This is a debug message";
int value = 10;
qDebug() << "The value is" << value;
        当执行这些代码时,它们会在应用程序的控制台输出相应的文本。这对于检查程序的运行状态、变量的 值或者跟踪程序的执行流程非常有帮助。
        还可以使用 qDebug() 来输出自定义类型,只要为这些类型提供了适当的输出操作符重载。此外, Qt 还 提供了 qInfo() , qWarning() , qCritical() qFatal() 函数,用于输出不同级别的信息,分别用 于普通信息、警告、关键错误和致命错误。这有助于对日志信息进行级别划分,从而更好地控制输出内
容。