亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

操作系統(tǒng)

Linux下精確控制時間的函數(shù)

時間:2024-07-31 22:58:12 操作系統(tǒng) 我要投稿
  • 相關(guān)推薦

Linux下精確控制時間的函數(shù)

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

Linux下精確控制時間的函數(shù)

  針對這種情況,使用CPU心跳的函數(shù)來處理時間,經(jīng)封裝后的函數(shù)得到時間精確,且使用方便。

  缺點:有一些機子由于硬件原因,可能不支持CPU心跳rdtscpll函數(shù)的使用,一般在虛擬機上都不行。

  使用情況:在我做機頂盒測試工具的時候,使用該方法去控制每秒鐘連接用戶數(shù)(每秒鐘連接100個用戶),測試效果比較理想,基本是每隔1秒鐘有100個用戶上線。

  下面貼上函數(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);//該處可以測試一些功能

  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;

  }

  執(zhí)行結(jié)果:

  測試一個功能 use time(us): 100,002,362

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

【Linux下精確控制時間的函數(shù)】相關(guān)文章:

Linux系統(tǒng)調(diào)用設(shè)備的ioctl函數(shù)03-08

Linux下Git的使用03-01

PHP怎么執(zhí)行Linux系統(tǒng)命令函數(shù)11-26

Linux系統(tǒng)時間設(shè)置11-22

Linux系統(tǒng)下的uname命令03-02

linux下防火墻設(shè)置02-24

Linux下如何學(xué)習(xí)C語言12-03

Linux系統(tǒng)下的進程切換的解析03-07

linux下卸載apache方法介紹11-15