訂閱
糾錯
加入自媒體

程序內如何計算一個函數(shù)的執(zhí)行時間?

2021-02-24 14:20
一口Linux
關注

關于時間的文章,大家可以參考我之前的一篇文章《C語言操作時間函數(shù),實現(xiàn)定時執(zhí)行某個任務小程序》

0、問題描述

粉絲想計算一個函數(shù)的執(zhí)行時間。

一、問題分析

函數(shù)的執(zhí)行時間的統(tǒng)計在嵌入式系統(tǒng)中會被頻繁的用到,知識點很重要。本文從兩個方面來討論類似的問題:

程序內計算一個函數(shù)的執(zhí)行時間計算一個程序的執(zhí)行時間

二、程序內如何計算一個函數(shù)的執(zhí)行時間?

1. 思路

我們在執(zhí)行函數(shù)前后分別記錄下時間戳,然后計算兩個時間戳的差值即可。

我們需要借助函數(shù)clock_gettime來實現(xiàn)這個功能。看下該函數(shù)的定義:

#include <time.h>
int clock_gettime(clockid_t clk_id, struct timespec* tp);
可以根據(jù)需要,獲取不同要求的精確時間
參數(shù):
clk_id :
檢索和設置的clk_id指定的時鐘時間。
CLOCK_REALTIME:系統(tǒng)實時時間,隨系統(tǒng)實時時間改變而改變,即從UTC1970-1-1 0:0:0開始計時,中間時刻如果系統(tǒng)時間被用戶改成其他,則對應的時間相應改變
 CLOCK_MONOTONIC:從系統(tǒng)啟動這一刻起開始計時,不受系統(tǒng)時間被用戶改變的影響
 CLOCK_PROCESS_CPUTIME_ID:本進程到當前代碼系統(tǒng)CPU花費的時間
 CLOCK_THREAD_CPUTIME_ID:本線程到當前代碼系統(tǒng)CPU花費的時間
tp :
獲取的時間戳會存放到該結構體變量中
struct timespec

        time_t tv_sec;  秒
        long tv_nsec;  納秒
};
返回值:
成功  0
失敗 -1  ,同時errno會被賦值

因為我們希望計算執(zhí)行某個函數(shù)的時間,所以我們第一個參數(shù)選擇CLOCK_MONOTONIC。

2. 實例1

我們先來實現(xiàn)一個簡單的程序:

 1 #include <stdio.h>                                                              
 2 #include <stdlib.h>
 3 #include <stdint.h>
 4 #include <time.h>
 5 #include <sys/time.h>
 6 #include <sys/stat.h>
 7 #include <sys/types.h>
 8 #include <unistd.h>
 9 #include <string.h>
10
11 int main()
12 {
13     int rc;
14     struct timespec ts_start, ts_end;
15    
16     //start time before call function
17     rc = clock_gettime(CLOCK_MONOTONIC, &ts_start);
18    
19     printf("you can call your function here");
20    
21     //end time before call function
22     rc = clock_gettime(CLOCK_MONOTONIC, &ts_end);
23    
24     printf("CLOCK_MONOTONIC reports %ld.%09ld seconds",
25             ts_end.tv_sec - ts_start.tv_sec, ts_end.tv_nsec - ts_start.tv_nsec);
26 }

19行 我們可以將自己要執(zhí)行的函數(shù)放置在此處。

1  2  下一頁>  
聲明: 本文由入駐維科號的作者撰寫,觀點僅代表作者本人,不代表OFweek立場。如有侵權或其他問題,請聯(lián)系舉報。

發(fā)表評論

0條評論,0人參與

請輸入評論內容...

請輸入評論/評論長度6~500個字

您提交的評論過于頻繁,請輸入驗證碼繼續(xù)

暫無評論

暫無評論

    掃碼關注公眾號
    OFweek人工智能網(wǎng)
    獲取更多精彩內容
    文章糾錯
    x
    *文字標題:
    *糾錯內容:
    聯(lián)系郵箱:
    *驗 證 碼:

    粵公網(wǎng)安備 44030502002758號