程序內(nèi)如何計算一個函數(shù)的執(zhí)行時間?
關(guān)于時間的文章,大家可以參考我之前的一篇文章《C語言操作時間函數(shù),實現(xiàn)定時執(zhí)行某個任務(wù)小程序》
0、問題描述
粉絲想計算一個函數(shù)的執(zhí)行時間。
一、問題分析
函數(shù)的執(zhí)行時間的統(tǒng)計在嵌入式系統(tǒng)中會被頻繁的用到,知識點很重要。本文從兩個方面來討論類似的問題:
程序內(nèi)計算一個函數(shù)的執(zhí)行時間計算一個程序的執(zhí)行時間
二、程序內(nèi)如何計算一個函數(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 :
檢索和設(shè)置的clk_id指定的時鐘時間。
CLOCK_REALTIME:系統(tǒng)實時時間,隨系統(tǒng)實時時間改變而改變,即從UTC1970-1-1 0:0:0開始計時,中間時刻如果系統(tǒng)時間被用戶改成其他,則對應(yīng)的時間相應(yīng)改變
CLOCK_M(jìn)ONOTONIC:從系統(tǒng)啟動這一刻起開始計時,不受系統(tǒng)時間被用戶改變的影響
CLOCK_PROCESS_CPUTIME_ID:本進(jìn)程到當(dāng)前代碼系統(tǒng)CPU花費的時間
CLOCK_THREAD_CPUTIME_ID:本線程到當(dāng)前代碼系統(tǒng)CPU花費的時間
tp :
獲取的時間戳?xí)娣诺皆摻Y(jié)構(gòu)體變量中
struct timespec
{
time_t tv_sec; 秒
long tv_nsec; 納秒
};
返回值:
成功 0
失敗 -1 ,同時errno會被賦值
因為我們希望計算執(zhí)行某個函數(shù)的時間,所以我們第一個參數(shù)選擇CLOCK_M(jìn)ONOTONIC。
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_M(jìn)ONOTONIC, &ts_start);
18
19 printf("you can call your function here");
20
21 //end time before call function
22 rc = clock_gettime(CLOCK_M(jìn)ONOTONIC, &ts_end);
23
24 printf("CLOCK_M(jìn)ONOTONIC 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ù)放置在此處。

請輸入評論內(nèi)容...
請輸入評論/評論長度6~500個字
最新活動更多
推薦專題
- 1 AI 眼鏡讓百萬 APP「集體失業(yè)」?
- 2 大廠紛紛入局,百度、阿里、字節(jié)搶奪Agent話語權(quán)
- 3 深度報告|中國AI產(chǎn)業(yè)正在崛起成全球力量,市場潛力和關(guān)鍵挑戰(zhàn)有哪些?
- 4 上海跑出80億超級獨角獸:獲上市公司戰(zhàn)投,干人形機器人
- 5 國家數(shù)據(jù)局局長劉烈宏調(diào)研格創(chuàng)東智
- 6 下一代入口之戰(zhàn):大廠為何紛紛押注智能體?
- 7 百億AI芯片訂單,瘋狂傾銷中東?
- 8 Robotaxi新消息密集釋放,量產(chǎn)元年誰在領(lǐng)跑?
- 9 格斗大賽出圈!人形機器人致命短板曝光:頭腦過于簡單
- 10 “搶灘”家用機器人領(lǐng)域,聯(lián)通、海爾、美的等紛紛入局