C語言有很多特殊的用法,如果這些特殊用法使用得當(dāng),會(huì)是你的代碼變得更加有健壯,更加容易維護(hù)。
比如我們在使用STM32庫的斷言(assert),你會(huì)發(fā)現(xiàn)官方提供了包含“__FILE__、__LINE__”的代碼。
標(biāo)準(zhǔn)外設(shè)庫位于stm32fxxx_conf.h文件:
#define assert_param(expr) ((expr) ? (void)0 : assert_failed((uint8_t *)__FILE__, __LINE__))
HAL使能Assert:
在代碼中會(huì)看見如下代碼:
如果添加了這段斷言代碼,對于開發(fā)大型、復(fù)雜的系統(tǒng),這條語句其實(shí)用處很大。每次程序運(yùn)行錯(cuò)誤之后,它會(huì)打印程序代碼指定的位置,方便我們在龐大的程序中很快找到錯(cuò)誤的位置。
我們的系統(tǒng)會(huì)隨著時(shí)間的推移,不斷升級更新,也就是需要提交很多版本的可執(zhí)行文件(hex、bin等)。但是,產(chǎn)品后期使用中,我們對某些設(shè)備進(jìn)行了升級,可能忽略了一些設(shè)備(忘記升級),如果出現(xiàn)故障,我們怎樣才能很快找到是哪一個(gè)版本的軟件出現(xiàn)故障呢?
我們的系統(tǒng)會(huì)隨著時(shí)間的推移,不斷升級更新,也就是需要提交很多版本的可執(zhí)行文件(hex、bin等)。但是,產(chǎn)品后期使用中,我們對某些設(shè)備進(jìn)行了升級,可能忽略了一些設(shè)備(忘記升級),如果出現(xiàn)故障,我們怎樣才能很快找到是哪一個(gè)版本的軟件出現(xiàn)故障呢?
C幾種特殊標(biāo)準(zhǔn)定義
__FILE__:正在編譯文件的文件名__LINE__:正在編譯文件的行號__DATE__:編譯時(shí)刻的日期字符串 如“Sep 22 2020”__TIME__:編譯時(shí)刻的時(shí)間字符串 如”1000“__STDC__:判斷該文件是不是標(biāo)準(zhǔn)C程序
1.__FILE__編譯文件名稱
File中文意思即文件,這里的意思主要是指:正在編譯文件對應(yīng)正在編譯文件的路徑和文件的名稱。
Keil版本對應(yīng)的路徑是相對于工程文件而言的路徑,IAR版本路徑是相對Windows路徑。
源代碼:
charBuildFile[]=__FILE__;printf("編譯文件路徑:%s ", BuildFile);
Keil:
編譯文件路徑:Appmain.c
IAR:
編譯文件路徑:C:UsersstrongerHuangDesktop工程主目錄Appmain.c
2.__LINE__編譯文件行號上面說的是編譯的文件名,是一個(gè)字符串,而這里說的是行號,是一個(gè)整型變量,這是這兩者的區(qū)別, 比如在工程中添加源代碼:
char BuildLine = __LINE__;printf("編譯代碼所在行:%d ", BuildLine); 可以看不是數(shù)組的字符串,打印信息: 編譯代碼所在行:44 一般情況下,__FILE__是和__LINE__結(jié)合一起使用,用于打印我們代碼信息,方便快速定位代碼位置。 3.__DATE__編譯日期__DATE__日期,需要注意的是:這個(gè)日期是你在編譯時(shí)Windows系統(tǒng)的日期,如果對應(yīng)那部分代碼之前編譯好了,后面沒有編譯,這個(gè)日期還是之前的日期,而不是后面編譯的日期。因此,如果這里用于定版本,就需要在定版本時(shí)對工程進(jìn)行全部重新編譯,它才會(huì)更新至你最后編譯的日期。 代碼:
char BuildDate[] = __DATE__;printf("編譯日期:%s ", BuildDate); 輸出結(jié)果: 編譯日期:Sep 22 2017 4.__TIME__編譯時(shí)間這個(gè)和__DATE__一樣的原理,編譯時(shí)的時(shí)間,也是一個(gè)字符串。 再次提醒:用于定版本:需要重新編譯,這樣才是最后一次編譯時(shí)間。 代碼:
char BuildTime[] = __TIME__;printf("編譯時(shí)間:%s ", BuildTime); 輸出結(jié)果 編譯時(shí)間:1000 5.__STDC__標(biāo)準(zhǔn)C代碼這個(gè)標(biāo)準(zhǔn)在我們單片機(jī)及嵌入式編程中運(yùn)用的比較少,當(dāng)要求程序嚴(yán)格遵循ANSIC標(biāo)準(zhǔn)時(shí)該標(biāo)識(shí)符被賦值為1,主要是判斷我們的程序文件是不是標(biāo)準(zhǔn)C程序。 代碼:
#ifdef __STDC__ printf("標(biāo)準(zhǔn)C代碼文件 ");#else printf("非標(biāo)準(zhǔn)C代碼文件 ");#endif推薦閱讀:
責(zé)任編輯:xj
原文標(biāo)題:__FILE__、__LINE__等幾種C標(biāo)準(zhǔn)用法
文章出處:【微信公眾號:strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
-
C語言
+關(guān)注
關(guān)注
180文章
7614瀏覽量
137420 -
File
+關(guān)注
關(guān)注
0文章
19瀏覽量
14362 -
Line
+關(guān)注
關(guān)注
0文章
26瀏覽量
11649
原文標(biāo)題:__FILE__、__LINE__等幾種C標(biāo)準(zhǔn)用法
文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論