a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > C > 正文

淺析Linux下精確控制時間的函數

2020-01-26 16:00:33
字體:
來源:轉載
供稿:網友
如果僅僅測試時間還行,但是如果程序中用到時間控制類的函數,如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): %lld/n",use_time);
        return 0;
}

執行結果:
測試一個功能 use time(us): 100,002,362
結論:由此可見,效果還是比較理想的。誤差極小,可以忽略。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 日日碰碰 | 精品欧美一区二区三区 | 久久青| 免费搞黄视频 | 日韩精品亚洲一区 | 操人网站 | 九九人人 | 成人精品一区二区三区中文字幕 | 亚洲国产精品久久 | 久久综合久久久 | 操网| 日韩一区二区三区在线 | 天天干欧美 | 亚洲高清免费 | 日日爱视频 | 欧美一级高清在线 | 欧美久草 | 日韩久久网 | 欧美日韩一区二区在线观看 | 精品不卡 | 精久久 | 久久人人爽人人爽人人片av不 | 91久久国产综合久久蜜月精品 | 99国产精品视频免费观看一公开 | 风间由美一区二区三区在线观看 | 国产成人一区二区三区 | 91精品国产乱码久久蜜臀 | 免费黄色网页 | 日本高清www | 日本在线免费 | 亚洲 中文 欧美 日韩 在线观看 | 日韩一区二区三区在线 | 亚洲第一免费网站 | 91麻豆产精品久久久 | 欧美日韩高清一区二区 | 国产精品久久久久久久久久久久冷 | 97久久精品午夜一区二区 | 中文字幕精品一区久久久久 | 99久久免费精品国产男女性高好 | 久久人人爽人人爽人人片av高清 | 久久久久国产 |