Linux下精確控制時間的函數
如果僅僅測試時間還行,但是如果程序中用到時間控制類的函數,如time, gettimeofday自身還會消耗不少時間,且增加程序執行的成本,這樣得到的.時間不精確。
針對這種情況,使用CPU心跳的函數來處理時間,經封裝後的函數得到時間精確,且使用方便。
缺點:有一些機子由於硬件原因,可能不支持CPU心跳rdtscpll函數的使用,一般在虛擬機上都不行。
使用情況:在我做機頂盒測試工具的時候,使用該方法去控制每秒鐘連接用户數(每秒鐘連接100個用户),測試效果比較理想,基本是每隔1秒鐘有100個用户上線。
下面貼上函數代碼:
複製代碼 代碼如下:
#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/(_sec*_sec*1000000+endt
__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): %lldn",use_time);
return 0;
}
執行結果:
測試一個功能 use time(us): 100,002,362
結論:由此可見,效果還是比較理想的。誤差極小,可以忽略。
-
計算機操作系統課程培訓學習體會
xxxx年11月20-22日,我們有幸參加了教育部全國高校教師操作系統培訓中心對國家精品課程《計算機操作系統課程》的課程培訓,聆聽了xxxx、xxxx兩位教授的講座,頗受啟發,收穫很多。回顧三天來的學習活動,深有感觸;回顧反省自己以往的教學生活,感慨良多。可以説本次培訓活...
-
Linux運維工程師崗位的職責
在現在社會,崗位職責的使用頻率逐漸增多,制定崗位職責可以減少違章行為和違章事故的發生。制定崗位職責的注意事項有許多,你確定會寫嗎?下面是小編為大家收集的Linux運維工程師崗位的職責,希望能夠幫助到大家。Linux運維工程師崗位的職責1職責:1、負責公司網站建立(...
-
Android操作系統的快捷鍵和技巧
1.首先就是最常用的技巧之一,長按Home鍵可以調出最近使用的6個程序,並將當前程序置入後台運行2.調整音量至最低,就會依次進入振動模式和電話鈴聲靜音3.長按掛機鍵,在彈出的進階菜單中可以選擇飛行模式、靜音模式和關機,但是值得一提的是,這裏的靜音室完全靜音,音樂盒...
-
Windows10的週年更新中無法關閉Cortana
導讀:備受期待的Windows10的週年更新中將會帶來諸多新特性,包括更實用的開始菜單、WindowsInk、強化的WindowsDefender,甚至還有一個無法關閉的語音助手Cortana。就跟隨本站小編一起去了解下吧,想了解更多相關信息請持續關注我們應屆畢業生考試網!目前在Windows10...