淺析Linux下精確控制時(shí)間的函數(shù)
更新時(shí)間:2013年07月10日 12:33:08 作者:
在測(cè)試程序接口運(yùn)行時(shí)間的時(shí)候,常用time,gettimeofday等函數(shù),但是這些函數(shù)在程序執(zhí)行的時(shí)候是耗費(fèi)時(shí)間的
如果僅僅測(cè)試時(shí)間還行,但是如果程序中用到時(shí)間控制類的函數(shù),如time, gettimeofday自身還會(huì)消耗不少時(shí)間,且增加程序執(zhí)行的成本,這樣得到的時(shí)間不精確。
針對(duì)這種情況,使用CPU心跳的函數(shù)來(lái)處理時(shí)間,經(jīng)封裝后的函數(shù)得到時(shí)間精確,且使用方便。
缺點(diǎn):有一些機(jī)子由于硬件原因,可能不支持CPU心跳rdtscpll函數(shù)的使用,一般在虛擬機(jī)上都不行。
使用情況:在我做機(jī)頂盒測(cè)試工具的時(shí)候,使用該方法去控制每秒鐘連接用戶數(shù)(每秒鐘連接100個(gè)用戶),測(cè)試效果比較理想,基本是每隔1秒鐘有100個(gè)用戶上線。
下面貼上函數(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));//使用心跳來(lái)代替妙
long long begin_time = GetCurCpuHopCount();
sleep(100);//該處可以測(cè)試一些功能
long long end_time = GetCurCpuHopCount();
long long use_time = (end_time - begin_time) * 1000000 / g_var_llOneSecJiffiesCount;
printf("測(cè)試一個(gè)功能 use time(us): %lld\n",use_time);
return 0;
}
執(zhí)行結(jié)果:
測(cè)試一個(gè)功能 use time(us): 100,002,362
結(jié)論:由此可見(jiàn),效果還是比較理想的。誤差極小,可以忽略。
針對(duì)這種情況,使用CPU心跳的函數(shù)來(lái)處理時(shí)間,經(jīng)封裝后的函數(shù)得到時(shí)間精確,且使用方便。
缺點(diǎn):有一些機(jī)子由于硬件原因,可能不支持CPU心跳rdtscpll函數(shù)的使用,一般在虛擬機(jī)上都不行。
使用情況:在我做機(jī)頂盒測(cè)試工具的時(shí)候,使用該方法去控制每秒鐘連接用戶數(shù)(每秒鐘連接100個(gè)用戶),測(cè)試效果比較理想,基本是每隔1秒鐘有100個(gè)用戶上線。
下面貼上函數(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));//使用心跳來(lái)代替妙
long long begin_time = GetCurCpuHopCount();
sleep(100);//該處可以測(cè)試一些功能
long long end_time = GetCurCpuHopCount();
long long use_time = (end_time - begin_time) * 1000000 / g_var_llOneSecJiffiesCount;
printf("測(cè)試一個(gè)功能 use time(us): %lld\n",use_time);
return 0;
}
執(zhí)行結(jié)果:
測(cè)試一個(gè)功能 use time(us): 100,002,362
結(jié)論:由此可見(jiàn),效果還是比較理想的。誤差極小,可以忽略。
相關(guān)文章
C語(yǔ)言所有經(jīng)典排序方法的實(shí)現(xiàn)代碼
這篇文章給大家分享C語(yǔ)言所有經(jīng)典排序方法,文章給大家提供完整的實(shí)例代碼幫助大家快速學(xué)習(xí)掌握C語(yǔ)言排序方法,感興趣的朋友一起看看吧2021-06-06
C語(yǔ)言中scanf與scnaf_s函數(shù)詳解
大家好,本篇文章主要講的是C語(yǔ)言中scanf與scnaf_s函數(shù)詳解,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下2022-01-01
C++開(kāi)源庫(kù)nlohmann/json的介紹和使用詳解
nlohmann/json?是一個(gè)C++實(shí)現(xiàn)的JSON解析器,使用非常方便直觀,這篇文章主要為大家詳細(xì)介紹了nlohmann/json的簡(jiǎn)介和使用,需要的可以參考下2023-12-12
基于樹(shù)莓派實(shí)現(xiàn)播放MP3音樂(lè)
這篇文章主要為大家詳細(xì)介紹了基于樹(shù)莓派實(shí)現(xiàn)播放MP3音樂(lè),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06
VC++ 字符串String MD5計(jì)算小工具 VS2008工程
基于字符串加密的MD5算法,VS2008 VC++,多字節(jié)編譯工程。主要代碼如下,實(shí)現(xiàn)了ANSI字符串加密與Unicode字符串加密,需要的朋友可以參考下2017-07-07
淺談C語(yǔ)言中的指針和數(shù)組有什么區(qū)別
C語(yǔ)言中的指針和數(shù)組是兩個(gè)重要的數(shù)據(jù)結(jié)構(gòu),它們?cè)趦?nèi)存管理和數(shù)據(jù)存儲(chǔ)方面有許多相似之處,但也存在一些關(guān)鍵的區(qū)別,本文就來(lái)介紹一下C語(yǔ)言中的指針和數(shù)組有什么區(qū)別,具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09
C語(yǔ)言循環(huán)鏈表實(shí)現(xiàn)貪吃蛇游戲
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言循環(huán)鏈表實(shí)現(xiàn)貪吃蛇,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11

