淺析Linux下精確控制時間的函數(shù)
更新時間:2013年07月10日 12:33:08 作者:
在測試程序接口運行時間的時候,常用time,gettimeofday等函數(shù),但是這些函數(shù)在程序執(zhí)行的時候是耗費時間的
如果僅僅測試時間還行,但是如果程序中用到時間控制類的函數(shù),如time, gettimeofday自身還會消耗不少時間,且增加程序執(zhí)行的成本,這樣得到的時間不精確。
針對這種情況,使用CPU心跳的函數(shù)來處理時間,經(jīng)封裝后的函數(shù)得到時間精確,且使用方便。
缺點:有一些機子由于硬件原因,可能不支持CPU心跳rdtscpll函數(shù)的使用,一般在虛擬機上都不行。
使用情況:在我做機頂盒測試工具的時候,使用該方法去控制每秒鐘連接用戶數(shù)(每秒鐘連接100個用戶),測試效果比較理想,基本是每隔1秒鐘有100個用戶上線。
下面貼上函數(shù)代碼:
#include <stdio.h>
#include <unistd.h>
#include <sys/time.h>
#include <asm/msr.h>
long long g_var_llOneSecJiffiesCount = 0;
long long GetCurCpuHopCount()
{
long long llcurrentcpuhopcount;
int iaux;
rdtscpll(llcurrentcpuhopcount,iaux);
return llcurrentcpuhopcount;
}
int main(int argc, char* argv[])
{
long long llstartvalue = 0;
long long llendvalue = 0;
struct timeval starttm,endtm;
int iaux = 0;
gettimeofday(&starttm,NULL);
rdtscpll(llstartvalue,iaux);
sleep(3);
rdtscpll(llendvalue,iaux);
gettimeofday(&endtm,NULL);
g_var_llOneSecJiffiesCount = ((llendvalue-llstartvalue)*1000000/(endtm.tv_sec*1000000-starttm.tv_sec*1000000+endt
m.tv_usec-starttm.tv_usec));//使用心跳來代替妙
long long begin_time = GetCurCpuHopCount();
sleep(100);//該處可以測試一些功能
long long end_time = GetCurCpuHopCount();
long long use_time = (end_time - begin_time) * 1000000 / g_var_llOneSecJiffiesCount;
printf("測試一個功能 use time(us): %lld\n",use_time);
return 0;
}
執(zhí)行結(jié)果:
測試一個功能 use time(us): 100,002,362
結(jié)論:由此可見,效果還是比較理想的。誤差極小,可以忽略。
針對這種情況,使用CPU心跳的函數(shù)來處理時間,經(jīng)封裝后的函數(shù)得到時間精確,且使用方便。
缺點:有一些機子由于硬件原因,可能不支持CPU心跳rdtscpll函數(shù)的使用,一般在虛擬機上都不行。
使用情況:在我做機頂盒測試工具的時候,使用該方法去控制每秒鐘連接用戶數(shù)(每秒鐘連接100個用戶),測試效果比較理想,基本是每隔1秒鐘有100個用戶上線。
下面貼上函數(shù)代碼:
復(fù)制代碼 代碼如下:
#include <stdio.h>
#include <unistd.h>
#include <sys/time.h>
#include <asm/msr.h>
long long g_var_llOneSecJiffiesCount = 0;
long long GetCurCpuHopCount()
{
long long llcurrentcpuhopcount;
int iaux;
rdtscpll(llcurrentcpuhopcount,iaux);
return llcurrentcpuhopcount;
}
int main(int argc, char* argv[])
{
long long llstartvalue = 0;
long long llendvalue = 0;
struct timeval starttm,endtm;
int iaux = 0;
gettimeofday(&starttm,NULL);
rdtscpll(llstartvalue,iaux);
sleep(3);
rdtscpll(llendvalue,iaux);
gettimeofday(&endtm,NULL);
g_var_llOneSecJiffiesCount = ((llendvalue-llstartvalue)*1000000/(endtm.tv_sec*1000000-starttm.tv_sec*1000000+endt
m.tv_usec-starttm.tv_usec));//使用心跳來代替妙
long long begin_time = GetCurCpuHopCount();
sleep(100);//該處可以測試一些功能
long long end_time = GetCurCpuHopCount();
long long use_time = (end_time - begin_time) * 1000000 / g_var_llOneSecJiffiesCount;
printf("測試一個功能 use time(us): %lld\n",use_time);
return 0;
}
執(zhí)行結(jié)果:
測試一個功能 use time(us): 100,002,362
結(jié)論:由此可見,效果還是比較理想的。誤差極小,可以忽略。
相關(guān)文章
C/C++實現(xiàn)個人收支系統(tǒng)的示例代碼
這篇文章主要介紹了C/C++實現(xiàn)個人收支系統(tǒng),本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06
C/C++判斷傳入的UTC時間是否當(dāng)天的實現(xiàn)方法
在項目中經(jīng)常會顯示一個時間,如果這個時間在今日內(nèi)就顯示為時分秒,否則顯示為年月日,有需要的朋友可以參考一下2014-01-01
C++基礎(chǔ)學(xué)習(xí)之利用兩個棧實現(xiàn)一個隊列
這篇文章主要給大家介紹了關(guān)于C++基礎(chǔ)學(xué)習(xí)之利用兩個棧實現(xiàn)一個隊列的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用C++具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05

