#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
创建两个类,比如Sender
和Receiver
。Sender
类将发出信号,而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()
函数,用于输出不同级别的信息,分别用 于普通信息、警告、关键错误和致命错误。这有助于对日志信息进行级别划分,从而更好地控制输出内
容。