程序內如何計算一個函數(shù)的執(zhí)行時間?
關于時間的文章,大家可以參考我之前的一篇文章《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ù)放置在此處。

請輸入評論內容...
請輸入評論/評論長度6~500個字
最新活動更多
推薦專題
- 1 UALink規(guī)范發(fā)布:挑戰(zhàn)英偉達AI統(tǒng)治的開始
- 2 北電數(shù)智主辦酒仙橋論壇,探索AI產(chǎn)業(yè)發(fā)展新路徑
- 3 降薪、加班、裁員三重暴擊,“AI四小龍”已折戟兩家
- 4 “AI寒武紀”爆發(fā)至今,五類新物種登上歷史舞臺
- 5 國產(chǎn)智駕迎戰(zhàn)特斯拉FSD,AI含量差幾何?
- 6 光計算迎來商業(yè)化突破,但落地仍需時間
- 7 東陽光:2024年扭虧、一季度凈利大增,液冷疊加具身智能打開成長空間
- 8 地平線自動駕駛方案解讀
- 9 封殺AI“照騙”,“淘寶們”終于不忍了?
- 10 優(yōu)必選:營收大增主靠小件,虧損繼續(xù)又逢關稅,能否乘機器人東風翻身?