【QT】定时器使用

news2024/9/23 21:30:03

文章目录

  • 关于 Qt 定时器使用的注意细节总结
  • 实例-检查工具使用周期时间是否合理
    • UI设计
    • 头文件 remind.h
    • 源文件 remind.cpp
    • 实现效果

关于 Qt 定时器使用的注意细节总结

一、创建与初始化

  1. 使用 QTimer 类来创建定时器。可以在构造函数中指定父对象,确保定时器在正确的对象生命周期内被管理。
    • 例如:QTimer *timer = new QTimer(this);,这里的 this 表示定时器的父对象,通常是一个 QObject 派生类的实例,这样可以确保在父对象销毁时,定时器也能被正确清理。

二、设置时间间隔

  1. 通过 setInterval 方法设置定时器的时间间隔,单位为毫秒。
    • 例如:timer->setInterval(1000); 设置定时器每 1000 毫秒触发一次。

三、连接信号与槽

  1. 使用 connect 函数将定时器的 timeout 信号与相应的槽函数连接起来,以便在定时器超时时执行特定的操作。
    • 例如:connect(timer, &QTimer::timeout, this, &YourClass::yourSlotFunction);,当定时器超时时,会调用 YourClass 类中的 yourSlotFunction 槽函数。

四、启动定时器

  1. 使用 start 方法启动定时器,使其开始计时并按照设定的时间间隔触发信号。
    • 例如:timer->start();,启动定时器后,它会按照设定的时间间隔不断触发 timeout 信号。

五、静态变量与计数器的使用

  1. 在定时器的槽函数中,如果需要使用静态变量作为计数器,要注意其作用域和生命周期。确保在合适的时候进行初始化和更新,避免出现不可预期的结果。
    • 例如:在定时器超时处理槽函数中使用静态变量 cnt 作为计数器时,要清楚其在多次调用槽函数过程中的变化情况,避免出现计数错误或逻辑混乱。

六、注意资源管理

  1. 当不再需要定时器时,应及时停止并删除定时器对象,以避免资源泄漏。特别是在定时器的父对象生命周期结束时,要确保定时器也能被正确清理。
    • 例如:在对象的析构函数中,可以停止定时器并删除定时器指针,如 if (timer) { timer->stop(); delete timer; timer = nullptr; }

总之,在使用 Qt 定时器时,要注意正确地创建、初始化、连接信号与槽、启动和管理定时器资源,以确保定时器在应用程序中能够稳定、可靠地工作。

实例-检查工具使用周期时间是否合理

UI设计

在这里插入图片描述

头文件 remind.h

#ifndef REMIND_H
#define REMIND_H

#include <QDialog>
#include <QTimer>
#include <QDateTime>
#include <QDate>

// 引入生成的界面头文件
namespace Ui {
class remind;
}

// remind 类的定义
class remind : public QDialog
{
    Q_OBJECT
public:
    // 显式构造函数,接受一个父指针参数,默认为 nullptr
    explicit remind(QWidget *parent = nullptr);
    // 析构函数
    ~remind();
    // 获取 remind 类的唯一实例的静态方法
    static remind *get_instance(void);
    // 检查工具时间是否有效的方法
    void is_tool_time_vaild(void);
    // 表示剩余天数的成员变量
    int days;
public slots:
    // 进入按钮点击处理槽函数
    void do_button_enter_handle(void);
    // 退出按钮点击处理槽函数
    void do_button_exit_handle(void);
    // 定时器超时处理槽函数
    void do_timer_out_handle(void);
private:
    // 指向生成的界面类的指针
    Ui::remind *ui;
    // 静态成员变量,用于存储唯一的 remind 实例指针
    static remind* instance;
};

#endif // REMIND_H

源文件 remind.cpp

#include "Remind.h"
#include "ui_Remind.h"
#include <qDebug.h>

// 静态成员变量初始化,初始值为 nullptr,表示当前没有创建 remind 实例
remind* remind::instance = nullptr;

// remind 类的构造函数
remind::remind(QWidget *parent)
    : QDialog(parent)
    , ui(new Ui::remind)
{
    // 设置界面
    ui->setupUi(this);
    // 输出调试信息,表示 remind 对象构建了
    qDebug("remind 对象构建了");
    // 检查工具时间是否有效
    is_tool_time_vaild();
    // 连接进入按钮的点击信号与对应的槽函数
    connect(ui->pushButton_enter, &QPushButton::clicked, this, &remind::do_button_enter_handle);
    // 连接退出按钮的点击信号与对应的槽函数
    connect(ui->pushButton_exit, &QPushButton::clicked,this, &remind::do_button_exit_handle);
}

// remind 类的析构函数
remind::~remind()
{
    // 删除界面指针
    delete ui;
}

// 获取 remind 类的唯一实例的静态方法
remind* remind::get_instance(void)
{
    // 如果当前没有实例,则创建一个新的实例
    if (!instance) {
        instance = new remind();
    }
    // 返回实例指针
    return instance;
}

// 定时器超时处理槽函数
void remind::do_timer_out_handle(void)
{
// 定义自动进入的时间间隔为 3 秒
#define AUTO_ENTRY_TIME (3)
    static int cnt = AUTO_ENTRY_TIME;
    // 如果剩余天数大于等于 0,表示工具未过期
    if (days >= 0) {
        // 在文本浏览器中显示剩余时间
        ui->textBrowser->append(QString::number(cnt) + "s 后自动进入");
        // 当计数器为 0 时,接受对话框,即自动进入
        if (0 == cnt)
            accept();
    }
    // 计数器递减
    cnt--;
}

// 检查工具时间是否有效的方法
void remind::is_tool_time_vaild(void)
{
    // 输出调试信息,表示正在检查工具时间有效性
    qDebug("check tool time validity");
    // 创建一个定时器对象
    QTimer *timer = new QTimer(this);
    // 设置定时器的时间间隔为 1000 毫秒(1 秒)
    timer->setInterval(1000);
    // 连接定时器超时信号与 do_timer_out_handle 槽函数
    connect(timer, &QTimer::timeout, this, &remind::do_timer_out_handle);
    // 启动定时器
    timer->start();
    // 设置目标日期为 2024 年 9 月 14 日
    QDate targetDate(2024, 9, 14);
    // 获取当前日期时间
    QDateTime currentDateTime = QDateTime::currentDateTime();
    // 提取当前日期
    QDate currentDate = currentDateTime.date();
    // 计算当前日期与目标日期之间的天数差
    days = currentDate.daysTo(targetDate);
    // 拼接字符串并在文本浏览器中显示剩余有效期信息
    QString append = "剩余有效期 :";
    append += QString::number(days);
    append += "\n注意:本工具仅适用于 XXXXX 产品";
    ui->textBrowser->append(append);
    // 如果天数小于 0,表示工具已过期
    if (days < 0) {
        // 禁用退出按钮
        ui->pushButton_exit->setEnabled(false);
        // 在文本浏览器中显示过期提示信息
        ui->textBrowser->append("当前版本已过期,请联系开发人员");
    }
}

// 进入按钮点击处理槽函数
void remind::do_button_enter_handle(void)
{
    // 输出调试信息,表示进入按钮被点击
    qDebug("button_enter");

    // 调用 accept() 函数表示接受对话框,通常会导致对话框关闭并返回一个特定的值(通常是 QDialog::Accepted),表示用户选择了“进入”操作。
    accept();
}

// 退出按钮点击处理槽函数
void remind::do_button_exit_handle(void)
{
    // 输出调试信息,表示退出按钮被点击
    qDebug("button_exit");

    // 调用 reject() 函数表示拒绝对话框,通常会导致对话框关闭并返回一个特定的值(通常是 QDialog::Rejected),表示用户选择了“退出”操作。
    reject();
}

实现效果

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2138747.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

跨境电商代购新纪元:一键解锁全球好物,系统流程全揭秘

添加图片注释&#xff0c;不超过 140 字&#xff08;可选&#xff09; 在全球化日益加深的今天&#xff0c;跨境电商代购成为了连接消费者与世界各地优质商品的桥梁。本文将在CSDN平台上&#xff0c;深入剖析跨境电商代购系统的功能流程&#xff0c;带您一窥其背后的技术奥秘与…

vue3+ant design vue实现可编辑表格弹出气泡弹出窗~

1、这里主要是介绍下::v-deep伪元素的作用。用于穿透组件作用域&#xff0c;以便在组件内部修改样式。用来覆盖Ant Design Vue组件库中的样式 <a-table:dataSource"dataList":columns"columns":scroll"{ x: 100% }":pagination"false&q…

架构师备考的一些思考(四)

前言 对于数学&#xff0c;我们之前学的是对的&#xff0c;但不是真的&#xff0c;所以我们没有数学思维。 对于计算机&#xff0c;我们学校教的是对的&#xff0c;但不是真的&#xff0c;所以仅仅从学校学习知识的应届毕业生&#xff0c;不论985,211&#xff0c;本科&#xff…

优化深度学习模型训练过程:提升PASCAL VOC 2012数据集上Deeplabv3+模型训练效率的策略

创作不易&#xff0c;您的打赏、关注、点赞、收藏和转发是我坚持下去的动力&#xff01; 优化说明&#xff1a; 避免重复下载和解压数据集&#xff1a;将downloadTrue改为downloadFalse&#xff0c;防止每次运行代码都重新下载和解压数据集&#xff0c;从而节省时间。 使用pin…

8. Transforms的使用(三)-- Resize

Transforms的使用(三) 1. 为什么要使用Resize 在模型的训练过程中往往需要图片数据的维度相同,才能适应深度学习模型中的相关神经网络结构,这时候就需要使用Resize保证所有的图片保持相同的尺寸2. 使用Resize调整图片的尺寸 在pytorch2.3的版本上,Resize()支持对Tensor类…

k8s Service 服务

文章目录 一、为什么需要 Service二、Kubernetes 中的服务发现与负载均衡 -- Service三、用例解读1、Service 语法2、创建和查看 Service 四、Headless Service五、集群内访问 Service六、向集群外暴露 Service七、操作示例1、获取集群状态信息2、创建 Service、Deployment3、创…

分贝转换 1 mVpp = 9.03dBmV

分贝转换 1 mVpp 9.03dBmV 函数发生器调节如下参数在频谱仪器上能看到9.03dBmv的电压值函数发生器产生 30mVpp 频谱仪会显示多少dBmV 函数发生器调节如下参数 输出频率&#xff1a;10 MHz 波形类型&#xff1a;正弦波 阻抗&#xff1a;50 Ω 幅度&#xff1a;1 mVpp …

【笔记】CCF直播:《如何在国际会议上有效交流》(2024-9-15)

目录 一、提问的勇气二、提问什么三、其他主题的报告为什么听四、会议前怎么读大量论文&#xff1f;五、workshop为什么参加&#xff1f;Poster环节&#xff1f;六、提问环节七、其他 今天听了《如何在国际会议上有效交流》的直播讲座&#xff0c;记录一些笔记。 一、提问的勇…

Gitlab及Git使用说明

目 录 1 Gitlab及Git介绍说明 5 1.1 什么是 Gitlab 5 1.2 什么是Git 5 1.3 Git 家族成员 5 1.4 Gitlab版本 5 1.5 Gitlab 优势 5 1.6 Gitlab 主要服务构成 6 1.7 Gitlab 简单工作流程 6 1.8 Gitlab用户角色 6 2 Gitlab安装与使用 7 2.1 Gitlab安装说明&#xff08;管理员&#…

文心智能体应用:美国旅游助手的诞生

创造灵感 在如今的数字化时代&#xff0c;旅行体验越来越依赖于智能技术的辅助。从机票预订到行程安排&#xff0c;再到当地美食推荐&#xff0c;智能助手在旅行中的作用愈发重要。尤其在美国这样一个广袤且多样化的国家&#xff0c;拥有一个智能旅行助手能够极大地提升游客的…

地震勘探原理视频总结(1-6)

目录 一、为什么要学好这门课&#xff1f; 1.1 为什么要学这门课&#xff08;为啥学&#xff09;&#xff1f; 1.2 课程包括哪些主要内容&#xff08;学什么&#xff09;&#xff1f; 1.3 如何学好这门课&#xff08;怎么学&#xff09;&#xff1f; 二、石油的生成与聚集…

网络安全有救了,37所高校新增网络安全空间安全专业

《网安面试指南》http://mp.weixin.qq.com/s?__bizMzkwNjY1Mzc0Nw&mid2247484339&idx1&sn356300f169de74e7a778b04bfbbbd0ab&chksmc0e47aeff793f3f9a5f7abcfa57695e8944e52bca2de2c7a3eb1aecb3c1e6b9cb6abe509d51f&scene21#wechat_redirect 《Java代码审…

Google提出 Speculative RAG:通过草稿机制增强检索增强生成

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

【自动化测试】自动化测试的价值和误区以及如何高效实用地落地自动化测试

引言 自动化并不仅仅是机器“点点点”的操作。虽然从表面上看&#xff0c;自动化测试确实涉及到了机器按照预设的脚本进行一系列的操作&#xff0c;但它的内涵远比这要丰富得多 高效实用地落地自动化测试&#xff0c;需要从策略规划、工具选择、团队协作、持续改进等多个方面进…

黑神话悟空:上架27天后,玩家群体分析

按9月13日的统计&#xff0c;仅在steam平台上&#xff0c;售出1900w份&#xff0c;约65亿人民币。 &#xff08;游戏于2024年8月20日发售&#xff09; 由于黑神话的关卡是线性的&#xff0c;即必须一关打过才能打下一关&#xff0c;和游戏的成就系统对应&#xff0c;所以可以…

C++:入门基础

一.C参考文档 https://legacy.cplusplus.com/reference/ https://zh.cppreference.com/w/cpp https://en.cppreference.com/w/ 二.C的第一个程序 #include <iostream> using namespace std;int main() {cout << "Hello world!" << en…

Node.js的学习2——内置模块(一)

Node.js的内置模块 module模块global全局变量Console控制台Errors错误模块捕获异常异步方法通过回调函数传递异常事件触发器对象异常捕获 module模块 使用module模块可以查看Node.js所有的内置模块、在所有模块中都可以使用的全局变量、程序在运行过程中可能会出现的四类错误。…

Git项目管理工具

分布式版本控制系统

快速生成服务器响应json-server的安装和使用

json-server介绍地址:https://www.geeksforgeeks.org/json-server-setup-and-introduction/ 1.json-server是什么? 基于自定义的json文件,快速生成服务端响应,可用于前端调试接口 2.安装和卸载json-server 2.1 安装: 使用npm命令: npm install -g json-server 2.2 卸载 npm …

“药乡”怀化,按下产业向海“加速键”

怀化&#xff0c;这座被火车拖来的城市&#xff0c;拥有什么独特的产业优势吗&#xff1f; 很多人不知道的是&#xff0c;怀化在整个医药领域可是大名鼎鼎的“中国道地药材之乡”&#xff0c;中药材资源蕴藏量居湖南省第一。尤其是怀化靖州&#xff0c;这里年集散茯苓11万吨&a…