Qt?QDateTime計算時間差的實現(xiàn)示例
前言
如果一個程序比較耗時,我們又想知道性能的瓶頸在哪里,然后針對性的進(jìn)行優(yōu)化。這里暫時不考慮多線程的情況。Qt中與時間相關(guān)的類大概有以下幾個:
1.QDateTime
2.QTime
3.QDate
4.QTimeZone
5.QCalendar
是不是有點頭大,反正我是懵圈了。。。。。。
這篇文章主要聊聊QDateTime
一、QDateTime

二、常用的函數(shù)
主要有以下常用函數(shù)


從官網(wǎng)描述來看大概意思:QDateTime 對象編碼日歷日期和時鐘時間(“日期時間”)。它結(jié)合了QDate和QTime類的特性。它可以從系統(tǒng)時鐘中讀取當(dāng)前日期時間。它提供了比較日期時間和通過添加秒數(shù)、天數(shù)、月數(shù)或年數(shù)來操作日期時間的函數(shù)。
1.示例代碼
#include "MainWindow.h"
#include <QApplication>
#include <QTime>
#include <QDateTime>
#include <QDebug>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
MainWindow w;
// w.show();
// int iCount[10000000] = {1};
int *pAllocation = new int[10000000];
int item = 0;
QDateTime time1 = QDateTime::currentDateTime();
QTime startTime = QTime::currentTime();
for(quint64 i=0; i<9000000000; i++)
{
item = i;
}
QDateTime time2 = QDateTime::currentDateTime();
int days = time1.daysTo(time2);
qDebug() << "Cast days=" << days;
quint64 sTime = time1.toTime_t();
quint64 eTime = time2.toTime_t();
quint64 costTime = eTime - sTime;
qDebug() << "eTime - sTime=" << costTime;
QDateTime elapseTime = QDateTime::fromTime_t(costTime);
qDebug() << "Elapsed time=" << elapseTime;
QTime endTime = QTime::currentTime();
int elapsed = startTime.secsTo(endTime);
qDebug() << startTime.secsTo(endTime);
// int ndaysec = 24*60*60;
// qDebug() << "Day = " << (etime - stime)/(ndaysec) + ((etime - stime)%(ndaysec)+(ndaysec-1))/(ndaysec) - 1;
QDateTime dateTime;
QString elapsedTime = dateTime.fromTime_t(elapsed).toString("yyyy-MM-dd hh:mm:ss[:zzz]");
qDebug() << "Cast time=" << elapsedTime;
return a.exec();
}
注意如果考慮毫秒、微秒、納秒級在計算時間差的時候,建議使用quint64,否則很容易溢出。
另外boost當(dāng)中的chrono也非常好用,而且精確度可以達(dá)到納秒級,當(dāng)然這里是考慮了cpu的時鐘頻率。
#include <iostream>
#define BOOST_DATE_TIME_POSIX_TIME_STD_CONFIG // 必須在頭文件之前定義宏,否則無效!??!
#include <boost/date_time/posix_time/posix_time.hpp>
int main(int argc, char **argv) {
// 第四個參數(shù),如果精確度是微秒,單位就是微秒,如果精確度是納秒,單位就是納秒
boost::posix_time::time_duration td(1, 10, 30, 1000); // 01:10:30
// 查看當(dāng)前的精確度
if (td.resolution() == boost::date_time::nano) printf("精確度:納秒\n");
else printf("精確度:微秒\n");
// 返回秒的小數(shù)部分的位數(shù)(微秒6位,納秒9位)
std::cout << td.num_fractional_digits() << std::endl;
// 對于以下輸出,默認(rèn)微秒精度輸出:01:10:30.001000 納秒精度輸出:01:10:30.000001000
std::cout << td << std::endl;
// 對于以下輸出,在納秒精度下,微秒會被忽略(微秒:4230001 納秒:4230000)
std::cout << td.total_milliseconds() << std::endl;
// 下面的這個方法,就是輸出小數(shù)點后面的數(shù)值,單位隨精確度變化
std::cout << td.fractional_seconds() << std::endl;
return 0;
}
2.日期與時間戳互轉(zhuǎn)
QString starttime ="2022-11-11 12:00:00"; QString endtime = "2022-11-13 12:00:01"; QDateTime start = QDateTime::fromString(starttime, "yyyy-MM-dd hh:mm:ss"); QDateTime end = QDateTime::fromString(endtime, "yyyy-MM-dd hh:mm:ss"); uint stime = start.toTime_t(); uint etime = end.toTime_t(); QDateTime time = QDateTime::fromTime_t(timeT);
到此這篇關(guān)于Qt QDateTime計算時間差的實現(xiàn)示例的文章就介紹到這了,更多相關(guān)Qt QDateTime計算時間差內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在C語言項目中有效進(jìn)行異常處理機(jī)制(最新推薦)
本文將探討在C語言項目中如何設(shè)計和實現(xiàn)錯誤處理機(jī)制,以確保程序的健壯性和可靠性,感興趣的朋友一起看看吧2025-03-03

