Qt?QDateTime計算時間差的實現(xià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)時鐘中讀取當前日期時間。它提供了比較日期時間和通過添加秒數(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當中的chrono也非常好用,而且精確度可以達到納秒級,當然這里是考慮了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 // 查看當前的精確度 if (td.resolution() == boost::date_time::nano) printf("精確度:納秒\n"); else printf("精確度:微秒\n"); // 返回秒的小數(shù)部分的位數(shù)(微秒6位,納秒9位) std::cout << td.num_fractional_digits() << std::endl; // 對于以下輸出,默認微秒精度輸出: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語言中多維數(shù)組的內(nèi)存分配和釋放(malloc與free)的方法
寫代碼的時候會碰到多維數(shù)組的內(nèi)存分配和釋放問題,在分配和釋放過程中很容易出現(xiàn)錯誤。下面貼上一些示例代碼,以供參考。2013-05-05c語言?數(shù)據(jù)存儲與原碼?反碼?補碼詳細解析
不知道你是否和我一樣好奇,學習編程語言的同時想,各個數(shù)據(jù)類型是怎樣在我們的內(nèi)存中儲存的呢,如果你仔細深入了解的話,你會了解其中的樂趣,了解科學家們的偉大,了解c語言2022-02-02