QT5.14测量程序运行时间样例(附代码)

**程序运行时间是编程中的一项重要内容,本文将程序运行时间利用ui窗口实现可视化操作。其中利用两个最重要的库是
#include “QTimer”
#include “QElapsedTimer”
先利用QTimer生成两个指针,*timer(作用是间隔触发槽函数,执行发送消息); refresh_timer(作用是间隔一秒刷新界面,显示时间);再利用QElapsedTimer生成指针ElapsedTimer(作用记录程序运行时间)
注:我之前在网上看见的是利用库但是在我使用该库时,QT5.14告诉我该操作方法已经被遗弃。
代码如下:
头文件代码:
#ifndef WIDGET_H
#define WIDGET_H
#include “QTimer”
#include “QElapsedTimer”
#include “QWidget”
#include"QAbstractButton"
#include"QCheckBox"
QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE
class Widget : public QWidget
{
Q_OBJECT
public:
Widget(QWidget *parent = nullptr);
~Widget();
private slots:
void on_pushButton_start_clicked();//启动按钮
void refresh_deal();//界面刷新处理函数
void count_deal();//计数间隔运行时,发送消息次数
void timing();//启动定时测量操作
void on_pushButton_stop_clicked();
void on_pushButton_clicked();
private:
Ui::Widget *ui;
QTimer *timer;
QTimer *refresh_timer;
QElapsedTimer ElapsedTimer;
QCheckBox checkBox;//定时测量按键
int count1=0;//得到程序运行时间,毫秒单位
int count2=0;//统计定时测量次数
int Interval;//界面上刷新间隔时间
int lineEdit_Time;//定时测量总时间
double True_time=0.00;//程序运行时间初始化
};
#endif // WIDGET_H
Sources中代码:
#include “widget.h”
#include “ui_widget.h”
#include"QAbstractButton"
#include"QDebug"
#include"QCheckBox"
Widget::Widget(QWidget parent)
: QWidget(parent)
, ui(new Ui::Widget)
{
ui->setupUi(this);
timer=new QTimer;
refresh_timer=new QTimer;
ElapsedTimer=new QElapsedTimer ;
checkBox=ui->checkBox;//定时测量按键
connect(checkBox,SIGNAL(clicked(bool)),this,SLOT(timing()));
connect(refresh_timer,SIGNAL(timeout()),this,SLOT(refresh_deal()));
connect(timer,SIGNAL(timeout()),this,SLOT(count_deal()));
}
Widget::~Widget()
{
delete ui;
}
void Widget::on_pushButton_start_clicked()
{
refresh_timer->setInterval(1000);//时间间隔1秒,执行界面刷新操作
refresh_timer->start();
ElapsedTimer->start();//程序运行时间开始工作
}
void Widget::refresh_deal()
{
count1=ElapsedTimer->elapsed();//elapsed()函数的意思是流失的时间,与最近一次start相关
True_time=count1/1000.00;//得到程序运行时间以秒为单位
QString true_time;
true_time.setNum(True_time);
ui->lineEdit_runTime->setText(true_time);//显示在界面上
}
void Widget::on_pushButton_stop_clicked()
{
refresh_timer->stop();
count1=0;//将界面刷新操作停止
timer->stop();
count2=0;//将定时测量时间停止
}
void Widget::timing()
{
if(checkBox->isChecked())//定时测量时间左边的按钮被选中时执行操作
{
QString interval=this->ui->lineEdit_refresh->text();//获取刷新间隔,字符串类型
Interval=interval.toInt();//得到的整型,谱线刷新间隔时间
QString lineEdit_time=this->ui->lineEdit_timing->text();//获取定时测量时间,字符串型
lineEdit_Time=lineEdit_time.toInt();//得到的整型,定时测量时间
on_pushButton_start_clicked();//启动测量
timer->setInterval(Interval
1000);
timer->start();//开始统计定时测量次数
qDebug()<<“按键选中”;
}else{on_pushButton_stop_clicked();//停止}
}
void Widget:: count_deal()
{
count2++;
on_pushButton_clicked();//发送消息
int TotalNumber=lineEdit_Time/ Interval;//利用定时测量时间除以刷新间隔得到刷新次数
if(count2>=TotalNumber){
timer->stop();
count2=0;
refresh_deal();//注意:要先再次刷新界面后再将控制刷新界面的定时器关闭,不然显示的时间有问题
refresh_timer->stop();
count1=0;
}
qDebug()< }
void Widget::on_pushButton_clicked()
{
qDebug()<<“发送消息”;
}
得到现象:运行半个小时,时间显示
QT5.14测量程序运行时间样例(附代码)_第1张图片

你可能感兴趣的:(qt)