- 相關(guān)推薦
Linux下精確控制時(shí)間的函數(shù)
如果僅僅測(cè)試時(shí)間還行,但是如果程序中用到時(shí)間控制類的函數(shù),如time, gettimeofday自身還會(huì)消耗不少時(shí)間,且增加程序執(zhí)行的成本,這樣得到的時(shí)間不精確。
針對(duì)這種情況,使用CPU心跳的函數(shù)來處理時(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
#include
#include
#include
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);//該處可以測(cè)試一些功能
long long end_time = GetCurCpuHopCount();
long long use_time = (end_time - begin_time) * 1000000 / g_var_llOneSecJiffiesCount;
printf("測(cè)試一個(gè)功能 use time(us): %lldn",use_time);
return 0;
}
執(zhí)行結(jié)果:
測(cè)試一個(gè)功能 use time(us): 100,002,362
結(jié)論:由此可見,效果還是比較理想的。誤差極小,可以忽略。
【Linux下精確控制時(shí)間的函數(shù)】相關(guān)文章:
linux系統(tǒng)下如何使用assert函數(shù)05-09
linux語言中的mkdi函數(shù)05-15
Linux系統(tǒng)調(diào)用設(shè)備的ioctl函數(shù)03-01
Linux下Git的使用08-02
PHP執(zhí)行Linux系統(tǒng)命令函數(shù)的方法04-03
PHP怎么執(zhí)行Linux系統(tǒng)命令函數(shù)08-10