【QT】定时器使用

文章目录

  • 关于 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.mfbz.cn/a/881072.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【C++】STL----list常见用法

&#x1f525;个人主页&#x1f525;&#xff1a;孤寂大仙V &#x1f308;收录专栏&#x1f308;&#xff1a;C从小白到高手 &#x1f339;往期回顾&#x1f339;&#xff1a;[C]vector常见用法 &#x1f516; 流水不争&#xff0c;争的是滔滔不息。 文章目录 一、list的介绍li…

【网络通信基础与实践第二讲】包括互联网概述、互联网发展的三个阶段、互联网的组成、计算机网络的体系结构

一、互联网概述 计算机网络是由若干节点&#xff08;node&#xff09;和连接这些节点的链路&#xff08;link&#xff09;组成。 网络之间还可以通过路由器互联起来&#xff0c;这就构成了一个覆盖范围更大的计算机网络。这样的网络称为互联网。 网络把许多计算机连接在一起…

SpringCloud-04 OpenFeign服务调用与负载均衡

OpenFeign是一个声明式、模板化的HTTP客户端&#xff0c;它简化了在Java应用程序中调用RESTful API的过程。OpenFeign是Netflix开发的一个开源项目&#xff0c;它构建在Feign的基础上&#xff0c;为开发者提供了更加简单、灵活的方式来实现HTTP请求。OpenFeign的特点包括&#…

计算机网络:概述 - 性能指标

目录 一. 速率 二. 带宽 三. 吞吐量 四. 时延 五. 时延带宽积 六. 往返时间RTT 七. 利用率 八. 丢包率 此博客介绍计算机网络中的性能指标&#xff0c;性能指标从不同的角度来度量计算机网络的性能。下面介绍几个常用的性能指标&#xff1a; 一. 速率…

服务器非法关闭后MySQL服务启动失败

在写这篇文章前&#xff0c;我弄好了&#xff0c;写完之后把成功安装的几个MySQL都删除了&#xff0c;只留了最后测试成功的服务“mysql-test” ,然后点击运行&#xff0c;发现又出现上图的错误。心态炸了。 本以为定位到问题了&#xff0c;但是这个错误让我迷茫了。我只能临时…

基于spring的ssm整合

目录 基于spring的ssm整合 Spring 框架 SpringMVC 框架 MyBatis 框架 1.创建项目 2.导入依赖 3.导入sql 4.创建jdbc.propries文件 1&#xff09;mysql8以下 2&#xff09;mysql8以上的 5.创建mybatis-config.xml配置文件 6.创建spring-Config.xml文件 7.创建项目所需包和类 1&a…

.whl文件下载及pip安装

以安装torch_sparse库为例 一、找到自己需要的版本&#xff0c;点击下载。 去GitHub的pyg-team主页中找到pytorch-geometric包。网址如下&#xff1a; pyg-team/pytorch_geometric​github.com/pyg-team/pytorch_geometric 然后点击如图中Additional Libraries位置的here&am…

Android系统dumpsys命令详解

文章目录 1. dumpsys 的工作原理2. 基本使用方法执行 dumpsys限制 dumpsys 的输出 3. 常见的 dumpsys 服务1. Activity Manager (activity)2. Battery Service (battery)3. Window Manager (window)4. Package Manager (package)5. Power Manager (power)6. Media DRM (media.d…

青柠视频云——视频丢包(卡顿、花屏、绿屏)排查

一、问题说明 近期有客户反馈&#xff0c;接入平台的设备经常出来卡顿、花屏、录屏的情况&#xff0c;出现这样的场景很是尴尬。 客户是私有化部署在公网环境&#xff0c;于是我们联系客户&#xff0c;对问题进行追踪排查。 二、场景复现 我们现场情况确认的过程中&#xff0c;…

Web 安全基础教程:从零基础入门到精通

一、Web 安全概述 &#xff08;一&#xff09;Web 安全的定义与重要性 1.定义 Web 安全是指保护 Web 应用程序免受各种网络威胁&#xff0c;确保 Web 服务的保密性、完整性和可用性。在当今数字化时代&#xff0c;Web 应用广泛存在于各个领域&#xff0c;从电子商务到社交媒…

Vue 实现高级穿梭框 Transfer 封装

文章目录 01 基础信息1.1. 技术栈1.2. 组件设计a. 竖版设计稿b. 横版设计稿 02 技术方案&#xff08;1&#xff09;初定义数据&#xff08;2&#xff09;注意事项&#xff08;3&#xff09;逻辑草图 03 代码示例3.1. 组件使用3.2. 组件源码./TransferPlus/index.vue./TransferP…

《史上最简单的 SpringCloud 教程》

Finchley版本 Spring Cloud Finchley; Spring Boot 2.0.3 史上最简单的 SpringCloud 教程 | 第一篇: 服务的注册与发现&#xff08;Eureka&#xff09;(Finchley版本)史上最简单的SpringCloud教程 | 第二篇: 服务消费者&#xff08;restribbon&#xff09;(Finchley版本)史上最…

有没有自带财务管理功能的海外仓系统?

在全球化的商业环境中&#xff0c;海外仓作为连接国际市场的物流枢纽&#xff0c;其重要性日益凸显。然而&#xff0c;随着业务范围的扩展和费用类型的多样化&#xff0c;海外仓在财务管理上面临着诸多挑战。传统的手工计费和对账方式不仅耗时费力&#xff0c;而且容易出错&…

网关登录校验(2)----网关如何将用户信息传递给微服务

1.微服务获取用户信息 现在&#xff0c;网关已经可以完成登录校验并获取登录用户身份信息。但是当网关将请求转发到微服务时&#xff0c;微服务又该如何获取用户身份呢&#xff1f; 由于网关发送请求到微服务依然采用的是Http请求&#xff0c;因此我们可以将用户信息以请求头…

Zabbix 部署----安装Zabbix(业务主机)

目录 1、另外准备一台虚拟机(192.xx.xx.20) 设置主机名 关闭防火墙、selinux 准备zabbix-repo 安装zabbix-agent 配置主服务器地址 启动zabbix-agent&#xff1a;10050 1、另外准备一台虚拟机(192.xx.xx.20) 设置主机名 hostname web1 关闭防火墙、selinux syst…

【HTTP】请求“报头”(Host、Content-Length/Content-Type、User-Agent(简称 UA))

Host 表示服务器主机的地址和端口号 URL 里面不是已经有 Host 了吗&#xff0c;为什么还要写一次&#xff1f; 这里的 Host 和 URL 中的 IP 地址、端口什么的&#xff0c;绝大部分情况下是一样的&#xff0c;少数情况下可能不同当前我们经过某个代理进行转发。过程中&#xf…

『功能项目』QFrameWork道具栏物品生成【64】

我们打开上一篇63QFrameWork框架重构OnGUI的项目&#xff0c; OnGUI优点&#xff1a; 简单易用&#xff1a;OnGUI是基于代码的UI系统&#xff0c;对于简单的调试界面或者小型项目来说&#xff0c;可以快速实现UI需求。即时更新&#xff1a;OnGUI的UI元素是即时更新的&#xff…

STM32外设之LTDC/DMA2D—液晶显示(野火)

文章目录 显示屏有几种?基本参数控制?显存 LTDC 液晶控制器LTDC 结构框图LTDC 初始化结构体 LTDC_InitTypeDefLTDC 层级初始化结构体 DMA2D 图形加速器DMA2D 初始化结构体 要了解什么 屏幕是什么&#xff0c;有几种屏&#xff0c;有什么组成。 怎么控制&#xff0c;不同屏幕控…

vue3 透传 Attributes

前言 Vue 3 现在正式支持了多根节点的组件&#xff0c;也就是片段&#xff01; Vue 2.x 遵循单根节点组件的规则&#xff0c;即一个组件的模板必须有且仅有一个根元素。 为了满足单根节点的要求&#xff0c;开发者会将原本多根节点的内容包裹在一个<div>元素中&#x…

如何联系真正的开发者而非公司??

&#x1f3c6;本文收录于《全栈Bug调优(实战版)》专栏&#xff0c;主要记录项目实战过程中所遇到的Bug或因后果及提供真实有效的解决方案&#xff0c;希望能够助你一臂之力&#xff0c;帮你早日登顶实现财富自由&#x1f680;&#xff1b;同时&#xff0c;欢迎大家关注&&am…