程序內(nèi)如何計(jì)算一個(gè)函數(shù)的執(zhí)行時(shí)間?
關(guān)于時(shí)間的文章,大家可以參考我之前的一篇文章《C語(yǔ)言操作時(shí)間函數(shù),實(shí)現(xiàn)定時(shí)執(zhí)行某個(gè)任務(wù)小程序》
0、問題描述
粉絲想計(jì)算一個(gè)函數(shù)的執(zhí)行時(shí)間。
一、問題分析
函數(shù)的執(zhí)行時(shí)間的統(tǒng)計(jì)在嵌入式系統(tǒng)中會(huì)被頻繁的用到,知識(shí)點(diǎn)很重要。本文從兩個(gè)方面來討論類似的問題:
程序內(nèi)計(jì)算一個(gè)函數(shù)的執(zhí)行時(shí)間計(jì)算一個(gè)程序的執(zhí)行時(shí)間
二、程序內(nèi)如何計(jì)算一個(gè)函數(shù)的執(zhí)行時(shí)間?
1. 思路
我們?cè)趫?zhí)行函數(shù)前后分別記錄下時(shí)間戳,然后計(jì)算兩個(gè)時(shí)間戳的差值即可。
我們需要借助函數(shù)clock_gettime來實(shí)現(xiàn)這個(gè)功能?聪略摵瘮(shù)的定義:
#include <time.h>
int clock_gettime(clockid_t clk_id, struct timespec* tp);
可以根據(jù)需要,獲取不同要求的精確時(shí)間
參數(shù):
clk_id :
檢索和設(shè)置的clk_id指定的時(shí)鐘時(shí)間。
CLOCK_REALTIME:系統(tǒng)實(shí)時(shí)時(shí)間,隨系統(tǒng)實(shí)時(shí)時(shí)間改變而改變,即從UTC1970-1-1 0:0:0開始計(jì)時(shí),中間時(shí)刻如果系統(tǒng)時(shí)間被用戶改成其他,則對(duì)應(yīng)的時(shí)間相應(yīng)改變
CLOCK_M(jìn)ONOTONIC:從系統(tǒng)啟動(dòng)這一刻起開始計(jì)時(shí),不受系統(tǒng)時(shí)間被用戶改變的影響
CLOCK_PROCESS_CPUTIME_ID:本進(jìn)程到當(dāng)前代碼系統(tǒng)CPU花費(fèi)的時(shí)間
CLOCK_THREAD_CPUTIME_ID:本線程到當(dāng)前代碼系統(tǒng)CPU花費(fèi)的時(shí)間
tp :
獲取的時(shí)間戳?xí)娣诺皆摻Y(jié)構(gòu)體變量中
struct timespec
{
time_t tv_sec; 秒
long tv_nsec; 納秒
};
返回值:
成功 0
失敗 -1 ,同時(shí)errno會(huì)被賦值
因?yàn)槲覀兿M?jì)算執(zhí)行某個(gè)函數(shù)的時(shí)間,所以我們第一個(gè)參數(shù)選擇CLOCK_M(jìn)ONOTONIC。
2. 實(shí)例1
我們先來實(shí)現(xiàn)一個(gè)簡(jiǎ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ù)放置在此處。
發(fā)表評(píng)論
請(qǐng)輸入評(píng)論內(nèi)容...
請(qǐng)輸入評(píng)論/評(píng)論長(zhǎng)度6~500個(gè)字
最新活動(dòng)更多
-
11月20日火熱報(bào)名中>> 2024 智能家居出海論壇
-
11月28日立即報(bào)名>>> 2024工程師系列—工業(yè)電子技術(shù)在線會(huì)議
-
12月19日立即報(bào)名>> 【線下會(huì)議】OFweek 2024(第九屆)物聯(lián)網(wǎng)產(chǎn)業(yè)大會(huì)
-
即日-12.26火熱報(bào)名中>> OFweek2024中國(guó)智造CIO在線峰會(huì)
-
即日-2025.8.1立即下載>> 《2024智能制造產(chǎn)業(yè)高端化、智能化、綠色化發(fā)展藍(lán)皮書》
-
精彩回顧立即查看>> 【在線會(huì)議】多物理場(chǎng)仿真助跑新能源汽車
推薦專題
- 1 腦機(jī)接口芯片,華為出了新專利!
- 2 銀行業(yè)AI大模型,從入局到求變
- 3 巨頭搶布局,VC狂撒錢,為了能讓「AI讀心」這些公司卷瘋了
- 4 阿斯麥ASML:“骨折級(jí)”洋相,又成AI第一殺手?
- 5 蘋果市值創(chuàng)新高,iPhone 16能否助力突破4萬億美元大關(guān)?
- 6 地平線開啟配售,阿里百度各砸5000萬美金,市值最高超500億
- 7 小馬智行沖刺納斯達(dá)克:或成「全球Robotaxi第一股」,兩年半營(yíng)收約12億元
- 8 云從科技:營(yíng)收低迷與虧損加劇,2025年盈利目標(biāo)挑戰(zhàn)重重
- 9 AI奇跡:域名賣爆,無名小島意外賺2億
- 10 逆境求生,泄密風(fēng)波中的高精地圖
- 高級(jí)軟件工程師 廣東省/深圳市
- 自動(dòng)化高級(jí)工程師 廣東省/深圳市
- 光器件研發(fā)工程師 福建省/福州市
- 銷售總監(jiān)(光器件) 北京市/海淀區(qū)
- 激光器高級(jí)銷售經(jīng)理 上海市/虹口區(qū)
- 光器件物理工程師 北京市/海淀區(qū)
- 激光研發(fā)工程師 北京市/昌平區(qū)
- 技術(shù)專家 廣東省/江門市
- 封裝工程師 北京市/海淀區(qū)
- 結(jié)構(gòu)工程師 廣東省/深圳市