Qt--定时器的使用

本文详细介绍了Qt中的两种定时器:QObject类的定时器和QTimer类的定时器。讲解了它们的启动、结束、事件处理方式,以及各自的特点和使用场景。QTimer类定时器支持单次触发和多次触发,提供了丰富的公共接口和信号槽功能,如设置时间间隔、判断是否单发等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Qt提供了两种定时器,一种是QObject类的定时器,另一种是QTimer类的定时器。

(1)QObject类的定时器

如果该类直接或间接继承了QObject,就可以使用这个。

通过函数startTimer()来启动,通过killTimer()来结束,通过QTimerEvent来处理定时器事件。

函数原型:

int QObject::startTimer(int interval, Qt::TimerType timerType = Qt::CoarseTimer); 

void QObject::killTimer(int id); 

void QObject::timerEvent(QTimerEvent * event);

QObject提供的定时器通过startTimer(int interval)启动,该函数启动了一个时间间隔为interval毫秒的定时器,启动成功只返回一个定时器标志符,失败返回0,因为只返回一个标志符,所以无法获得该定时器的对象,它是QObject的成员函数,及不能正常的使用信号与槽,只能通过重载定时器事件处理函数,在里面写定时器触发要做的事:

[virtual protected] void QObject::timerEvent(QTimerEvent *event)

如果有多个定时器,可以通过QTimerEvent::timerId()来获取已经启动的定时器标识符。

该定时器只能通过killTimer(int id)杀死,参数id为之前生成定时器标志符,根据标志符杀死定时器。

class MyObject : public QObject
  {
      Q_OBJECT

  public:
      MyObject(QObject *parent = 0);

  protected:
   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值