精品丰满熟女一区二区三区_五月天亚洲欧美综合网_亚洲青青青在线观看_国产一区二区精选

  • <menu id="29e66"></menu>

    <bdo id="29e66"><mark id="29e66"><legend id="29e66"></legend></mark></bdo>

  • <pre id="29e66"><tt id="29e66"><rt id="29e66"></rt></tt></pre>

      <label id="29e66"></label><address id="29e66"><mark id="29e66"><strike id="29e66"></strike></mark></address>
      學(xué)習(xí)啦 > 學(xué)習(xí)電腦 > 操作系統(tǒng) > Linux教程 >

      linux用戶空間獲得ns納秒級時間方法是什么

      時間: 加城1195 分享

        Linux繼承了Unix以網(wǎng)絡(luò)為核心的設(shè)計思想,是一個性能穩(wěn)定的多用戶網(wǎng)絡(luò)操作系統(tǒng)。我們在測試程序的性能的時候往往需要獲得ns級的精確時間去衡量一個程序的性能,具體怎么使用呢?這篇文章主要介紹了linux用戶空間獲得ns納秒級時間示例,需要的朋友可以參考下

        方法步驟

        用戶空間獲得ns級時間

        使用clock_gettime函數(shù),函數(shù)原型如下:

        long sys_clock_gettime (clockid_t which_clock, struct timespec *tp);

        1.which_clock參數(shù)解釋

        CLOCK_REALTIME:系統(tǒng)實時時間,隨系統(tǒng)實時時間改變而改變,即從UTC1970-1-1 0:0:0開始計時,中間時刻如果系統(tǒng)時間被用戶該成其他,則對應(yīng)的時間相應(yīng)改變

        CLOCK_MONOTONIC:從系統(tǒng)啟動這一刻起開始計時,不受系統(tǒng)時間被用戶改變的影響

        CLOCK_PROCESS_CPUTIME_ID:本進程到當(dāng)前代碼系統(tǒng)CPU花費的時間

        CLOCK_THREAD_CPUTIME_ID:本線程到當(dāng)前代碼系統(tǒng)CPU花費的時間

        2.struct timespec結(jié)構(gòu)

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

        struct timespec

        {

        time_t tv_sec;

        long int tv_nsec;

        };

        使用范例代碼如下:

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

        #include

        #include

        #include

        int main(void)

        {

        struct timespec time_start={0, 0},time_end={0, 0};

        clock_gettime(CLOCK_REALTIME, &time_start);

        printf("start time %llus,%llu ns\n", time_start.tv_sec, time_start.tv_nsec);

        clock_gettime(CLOCK_REALTIME, &time_end);

        printf("endtime %llus,%llu ns\n", time_end.tv_sec, time_end.tv_nsec);

        printf("duration:%llus %lluns\n", time_end.tv_sec-time_start.tv_sec, time_end.tv_nsec-time_start.tv_nsec);

        return 0;

        }

        編譯命令:

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

        gcc test.c -o test -lrt

        運行結(jié)果:

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

        ./test

        start time 1397395863s,973618673 ns

        endtime 1397395863s,973633297 ns

        duration:0s 14624ns

        從運行結(jié)果可以看出 調(diào)用printf()函數(shù)一次需要15us左右。

        補充:Linux基本命令

        1.ls命令:

        格式::ls [選項] [目錄或文件]

        功能:對于目錄,列出該目錄下的所有子目錄與文件;對于文件,列出文件名以及其他信息。

        常用選項:

        -a :列出目錄下的所有文件,包括以 . 開頭的隱含文件。

        -d :將目錄像文件一樣顯示,而不是顯示其他文件。

        -i :輸出文件的i節(jié)點的索引信息。

        -k :以k字節(jié)的形式表示文件的大小。

        -l :列出文件的詳細信息。

        -n :用數(shù)字的UID,GID代替名稱。

        -F : 在每個文件名后面附上一個字符以說明該文件的類型,“*”表示可執(zhí)行的普通文 件;“/”表示目錄;“@”表示符號鏈接;“l”表示FIFOS;“=”表示套接字。

        2.cd命令

        格式:cd [目錄名稱]

        常用選項:

        cd .. 返回上一級目錄。

        cd ../.. 將當(dāng)前目錄向上移動兩級。

        cd - 返回最近訪問目錄。

        3.pwd命令

        格式: pwd

        功能:顯示出當(dāng)前工作目錄的絕對路徑。

        相關(guān)閱讀:Linux主要特性

        完全兼容POSIX1.0標(biāo)準(zhǔn)

        這使得可以在Linux下通過相應(yīng)的模擬器運行常見的DOS、Windows的程序。這為用戶從Windows轉(zhuǎn)到Linux奠定了基礎(chǔ)。許多用戶在考慮使用Linux時,就想到以前在Windows下常見的程序是否能正常運行,這一點就消除了他們的疑慮。

        多用戶、多任務(wù)

        Linux支持多用戶,各個用戶對于自己的文件設(shè)備有自己特殊的權(quán)利,保證了各用戶之間互不影響。多任務(wù)則是現(xiàn)在電腦最主要的一個特點,Linux可以使多個程序同時并獨立地運行。

        良好的界面

        Linux同時具有字符界面和圖形界面。在字符界面用戶可以通過鍵盤輸入相應(yīng)的指令來進行操作。它同時也提供了類似Windows圖形界面的X-Window系統(tǒng),用戶可以使用鼠標(biāo)對其進行操作。在X-Window環(huán)境中就和在Windows中相似,可以說是一個Linux版的Windows。

        支持多種平臺

        Linux可以運行在多種硬件平臺上,如具有x86、680x0、SPARC、Alpha等處理器的平臺。此外Linux還是一種嵌入式操作系統(tǒng),可以運行在掌上電腦、機頂盒或游戲機上。2001年1月份發(fā)布的Linux 2.4版內(nèi)核已經(jīng)能夠完全支持Intel 64位芯片架構(gòu)。同時Linux也支持多處理器技術(shù)。多個處理器同時工作,使系統(tǒng)性能大大提高。


      linux 時間相關(guān)文章:

      1.linux shell獲取當(dāng)前時間命令

      2.Linux系統(tǒng)修改時間用什么命令

      3.如何使用命令行更改Linux系統(tǒng)的日期和時間

      4.Linux C語言時間函數(shù)

      5.linux瀏覽器命令

      4019235