Linux下精確控制時間的函數

來源:互聯網
上載者:User

如果僅僅測試時間還行,但是如果程式中用到時間控制類的函數,如time,  gettimeofday自身還會消耗不少時間,且增加程式執行的成本,這樣得到的時間不精確。
針對這種情況,使用CPU心跳的函數來處理時間,經封裝後的函數得到時間精確,且使用方便。

缺點:有一些機子由於硬體原因,可能不支援CPU心跳rdtscpll函數的使用,一般在虛擬機器上都不行。
 
使用方式:在我做機頂盒測試載入器的時候,使用該方法去控制每秒鐘串連使用者數(每秒鐘串連100個使用者),測試效果比較理想,基本是每隔1秒鐘有100個使用者上線。

下面貼上函數代碼:

複製代碼 代碼如下:
#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): %lldn",use_time);
        return 0;
}


執行結果:
測試一個功能 use time(us): 100,002,362
結論:由此可見,效果還是比較理想的。誤差極小,可以忽略。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.