<address id="ousso"></address>
<form id="ousso"><track id="ousso"><big id="ousso"></big></track></form>
  1. Linux下精確控制時間的函數

    時間:2025-12-15 06:27:46 操作系統 我要投稿

    Linux下精確控制時間的函數

      如果僅僅測試時間還行,但是如果程序中用到時間控制類的函數,如time, gettimeofday自身還會消耗不少時間,且增加程序執行的成本,這樣得到的時間不精確。

    Linux下精確控制時間的函數

      針對這種情況,使用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/(endtm.tv_sec*1000000-starttm.tv_sec*1000000+endt

      m.tv_usec-starttm.tv_usec));/pic/p>

      long long begin_time = GetCurCpuHopCount();

      sleep(100);/pic/p>

      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

      結論:由此可見,效果還是比較理想的。誤差極小,可以忽略。

    【Linux下精確控制時間的函數】相關文章:

    linux系統下如何使用assert函數05-09

    linux語言中的mkdi函數05-15

    Linux系統調用設備的ioctl函數03-01

    Linux下Git的使用12-14

    Linux-poll函數深入理解05-10

    PHP執行Linux系統命令函數的方法04-03

    PHP怎么執行Linux系統命令函數10-19

    Linux系統時間設置03-25

    Linux系統下的uname命令11-11

    • 相關推薦
    <address id="ousso"></address>
    <form id="ousso"><track id="ousso"><big id="ousso"></big></track></form>
    1. 日日做夜狠狠爱欧美黑人