QT 中 QTimer 定时器类 备查

基础

// 指定了父对象, 创建的堆内存可以自动析构
QTimer::QTimer(QObject *parent = nullptr);

// 根据指定的时间间隔启动或者重启定时器, 需要调用 setInterval() 设置时间间隔
void QTimer::start();

// 启动或重新启动定时器,超时间隔为msec毫秒。
void QTimer::start(int msec);

// 停止定时器。
void QTimer::stop();

//当定时器超时时,该信号就会被发射出来。
[signal] void QTimer::timeout();

// 设置定时器时间间隔为 msec 毫秒,默认值是0。
void QTimer::setInterval
QTimerQt 提供的强大定时器类,适用于各种定时操作场景,可实现周期性任务、延时操作和动画等功能。以下是 QTimer 的使用方法介绍: ### 常用 API - `setInterval(int msec)`:设置定时器的时间间隔,单位为毫秒。 - `setSingleShot(bool singleShot)`:设置定时器是否只触发一次,默认为 `false`,即周期性触发。 - `start()`:开启定时器。 - `stop()`:停止定时器。 - `timeout()`:定时器超时信号,当定时器超时时会发出该信号。 - `singleShot(int msec, const QObject *receiver, const char *member)`:静态方法,用于只触发一次的定时器 [^3]。 ### 示例代码 以下是一个使用 QTimer 每秒生成一次随机数并显示在 `LCDNumber` 控件上的实例代码: ```cpp #include <QApplication> #include <QLCDNumber> #include <QTimer> #include <QVBoxLayout> #include <QWidget> #include <cstdlib> #include <ctime> int main(int argc, char *argv[]) { QApplication app(argc, argv); // 创建主窗口和布局 QWidget window; QVBoxLayout *layout = new QVBoxLayout(&window); // 创建 LCDNumber 控件 QLCDNumber *lcdNumber = new QLCDNumber(&window); layout->addWidget(lcdNumber); // 创建 QTimer 对象 QTimer *timer = new QTimer(&window); // 连接定时器的 timeout 信号到自定义槽函数 QObject::connect(timer, &QTimer::timeout, [lcdNumber]() { // 生成随机数 static bool initialized = false; if (!initialized) { std::srand(std::time(nullptr)); initialized = true; } int randomNumber = std::rand() % 100; // 生成 0 到 99 之间的随机数 // 在 LCDNumber 上显示随机数 lcdNumber->display(randomNumber); }); // 设置定时器的时间间隔为 1000 毫秒(即 1 秒) timer->setInterval(1000); // 启动定时器 timer->start(); // 显示主窗口 window.show(); return app.exec(); } ``` ### 注意事项 在使用 QTimer 时,应该避免在定时器的槽函数中执行耗时操作,因为这可能会阻塞 Qt 的事件循环,影响界面响应和其他定时器的准确性 [^3]。
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值