Qt QTimer测试定时精度

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

dialog.h文件

#ifndef DIALOG_H
#define DIALOG_H

#include <QDialog>
#include <QDateTime>

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 <QTimer>
#include <QDebug>

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()<<"===="<<abs(m_time.toMSecsSinceEpoch() - QDateTime::currentDateTime().toMSecsSinceEpoch());
    if(abs(m_time.toMSecsSinceEpoch() - QDateTime::currentDateTime().toMSecsSinceEpoch()) > 10000)
    {
        num++;
    }
    ui->exception->setText(QString::number(num));
    //校准事件
    m_time = QDateTime::currentDateTime();
}


效果图


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值