Qt?QDateTime計(jì)算時(shí)間差的實(shí)現(xiàn)示例
前言
如果一個(gè)程序比較耗時(shí),我們又想知道性能的瓶頸在哪里,然后針對(duì)性的進(jìn)行優(yōu)化。這里暫時(shí)不考慮多線程的情況。Qt中與時(shí)間相關(guān)的類大概有以下幾個(gè):
1.QDateTime
2.QTime
3.QDate
4.QTimeZone
5.QCalendar
是不是有點(diǎn)頭大,反正我是懵圈了。。。。。。
這篇文章主要聊聊QDateTime
一、QDateTime
二、常用的函數(shù)
主要有以下常用函數(shù)
從官網(wǎng)描述來看大概意思:QDateTime 對(duì)象編碼日歷日期和時(shí)鐘時(shí)間(“日期時(shí)間”)。它結(jié)合了QDate和QTime類的特性。它可以從系統(tǒng)時(shí)鐘中讀取當(dāng)前日期時(shí)間。它提供了比較日期時(shí)間和通過添加秒數(shù)、天數(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(); }
注意如果考慮毫秒、微秒、納秒級(jí)在計(jì)算時(shí)間差的時(shí)候,建議使用quint64,否則很容易溢出。
另外boost當(dāng)中的chrono也非常好用,而且精確度可以達(dá)到納秒級(jí),當(dāng)然這里是考慮了cpu的時(shí)鐘頻率。
#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) { // 第四個(gè)參數(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; // 對(duì)于以下輸出,默認(rèn)微秒精度輸出:01:10:30.001000 納秒精度輸出:01:10:30.000001000 std::cout << td << std::endl; // 對(duì)于以下輸出,在納秒精度下,微秒會(huì)被忽略(微秒:4230001 納秒:4230000) std::cout << td.total_milliseconds() << std::endl; // 下面的這個(gè)方法,就是輸出小數(shù)點(diǎn)后面的數(shù)值,單位隨精確度變化 std::cout << td.fractional_seconds() << std::endl; return 0; }
2.日期與時(shí)間戳互轉(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計(jì)算時(shí)間差的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Qt QDateTime計(jì)算時(shí)間差內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言中多維數(shù)組的內(nèi)存分配和釋放(malloc與free)的方法
寫代碼的時(shí)候會(huì)碰到多維數(shù)組的內(nèi)存分配和釋放問題,在分配和釋放過程中很容易出現(xiàn)錯(cuò)誤。下面貼上一些示例代碼,以供參考。2013-05-05C語言中結(jié)構(gòu)體和共用體實(shí)例教程
這篇文章主要給大家介紹了關(guān)于C語言中結(jié)構(gòu)體和共用體的相關(guān)資料,結(jié)構(gòu)體是一種自定義的復(fù)合數(shù)據(jù)類型,共用體也叫聯(lián)合體,使幾個(gè)不同類型的變量共占一段內(nèi)存(相互覆蓋),需要的朋友可以參考下2021-06-06c語言?數(shù)據(jù)存儲(chǔ)與原碼?反碼?補(bǔ)碼詳細(xì)解析
不知道你是否和我一樣好奇,學(xué)習(xí)編程語言的同時(shí)想,各個(gè)數(shù)據(jù)類型是怎樣在我們的內(nèi)存中儲(chǔ)存的呢,如果你仔細(xì)深入了解的話,你會(huì)了解其中的樂趣,了解科學(xué)家們的偉大,了解c語言2022-02-02C++中的繼承問題(繼承基本概念、菱形虛擬繼承的對(duì)象模型)
這篇文章主要介紹了C++中的繼承問題(繼承基本概念、菱形虛擬繼承的對(duì)象模型),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02