linux+qt+定时精度,Qt QTimer测试定时精度

调试信息输出窗口可以查看超时误差

dialog.h文件

#ifndef DIALOG_H

#define DIALOG_H

#include

#include

namespace Ui {

class Dialog;

}

class QTimer;

class Dialog : public QDialog

{

Q_OBJECT

public:

explicit Dialog(QWidget *parent = 0);

~Dialog();

public slots:

void slotOneSec();

private:

Ui::Dialog *ui;

QDateTime m_time;

QTimer *m_oneSecTimer;

int num;

};

#endif // DIALOG_H

dialog.cpp文件

#include "dialog.h"

#include "ui_dialog.h"

#include

#include

Dialog::Dialog(QWidget *parent) :

QDialog(parent),

ui(new Ui::Dialog)

{

ui->setupUi(this);

num = 0;

m_oneSecTimer = new QTimer();

connect(m_oneSecTimer, SIGNAL(timeout()), this, SLOT(slotOneSec()));

m_time = QDateTime::currentDateTime();

m_oneSecTimer->start(1000);

ui->myTime->setText(m_time.toString("hh:mm:ss"));

ui->computerTime->setText(QDateTime::currentDateTime().toString("hh:mm:ss"));

}

Dialog::~Dialog()

{

delete m_oneSecTimer;

delete ui;

}

void Dialog::slotOneSec()

{

m_time = m_time.addSecs(1);

ui->myTime->setText(m_time.toString("hh:mm:ss"));

ui->computerTime->setText(QDateTime::currentDateTime().toString("hh:mm:ss"));

//如果两次定时间隔大于10秒,次数就会+1

qDebug()<

if(abs(m_time.toMSecsSinceEpoch() - QDateTime::currentDateTime().toMSecsSinceEpoch()) > 10000)

{

num++;

}

ui->exception->setText(QString::number(num));

//校准事件

m_time = QDateTime::currentDateTime();

}

效果图

07dd3cc4597f58d35db54d1a61baaacf.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值