欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來(lái)到入門(mén)教程網(wǎng)!

C語(yǔ)言

當(dāng)前位置:主頁(yè) > 軟件編程 > C語(yǔ)言 >

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

來(lái)源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:C語(yǔ)言|點(diǎn)擊: 次

如果僅僅測(cè)試時(shí)間還行,但是如果程序中用到時(shí)間控制類(lèi)的函數(shù),如time,  gettimeofday自身還會(huì)消耗不少時(shí)間,且增加程序執(zhí)行的成本,這樣得到的時(shí)間不精確。
針對(duì)這種情況,使用CPU心跳的函數(shù)來(lái)處理時(shí)間,經(jīng)封裝后的函數(shù)得到時(shí)間精確,且使用方便。

缺點(diǎn):有一些機(jī)子由于硬件原因,可能不支持CPU心跳rdtscpll函數(shù)的使用,一般在虛擬機(jī)上都不行。
 
使用情況:在我做機(jī)頂盒測(cè)試工具的時(shí)候,使用該方法去控制每秒鐘連接用戶(hù)數(shù)(每秒鐘連接100個(gè)用戶(hù)),測(cè)試效果比較理想,基本是每隔1秒鐘有100個(gè)用戶(hù)上線(xiàn)。

下面貼上函數(shù)代碼:

復(fù)制代碼 代碼如下:

#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));//使用心跳來(lái)代替妙
        long long begin_time = GetCurCpuHopCount();
        sleep(100);//該處可以測(cè)試一些功能
        long long end_time = GetCurCpuHopCount();
        long long use_time = (end_time - begin_time) * 1000000 / g_var_llOneSecJiffiesCount;
        printf("測(cè)試一個(gè)功能 use time(us): %lld\n",use_time);
        return 0;
}

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

網(wǎng)頁(yè)制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語(yǔ)言數(shù)據(jù)庫(kù)服務(wù)器

如果侵犯了您的權(quán)利,請(qǐng)與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有