0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

ANSIC幾種特殊的標(biāo)準(zhǔn)定義 (__FILE__、__LINE__、__STDC__···)

黃工的嵌入式技術(shù)圈 ? 來(lái)源:黃工的嵌入式技術(shù)圈 ? 2020-03-20 09:46 ? 次閱讀

Ⅰ寫(xiě)在前面

為方便大家閱讀,本文內(nèi)容已經(jīng)整理成PDF文件:

http://pan.baidu.com/s/1gfHygyn

對(duì)于我們大部分使用單片機(jī)進(jìn)行裸機(jī)開(kāi)發(fā)的朋友來(lái)說(shuō),可能很少有人在程序中許多關(guān)鍵的地方打印一些關(guān)鍵信息。

有較大系統(tǒng)開(kāi)發(fā),或復(fù)雜系統(tǒng)開(kāi)發(fā)經(jīng)驗(yàn)的朋友一般都會(huì)在程序中輸出很多調(diào)試信息,如在UCOS、freeRTOS、Linux等系統(tǒng)開(kāi)發(fā)調(diào)試時(shí)打印許多關(guān)鍵信息。

1.我們?cè)谑褂?a href="http://ttokpm.com/v/tag/751/" target="_blank">STM32庫(kù)開(kāi)發(fā)時(shí),在stm32fxxx_conf.h文件下會(huì)發(fā)現(xiàn)如下這么一條語(yǔ)句:

#define assert_param(expr) ((expr) ? (void)0 : assert_failed((uint8_t *)__FILE__, __LINE__))

這條語(yǔ)句,對(duì)于使用寄存器,開(kāi)發(fā)簡(jiǎn)單且不大程序的朋友而言,可能他覺(jué)得用處不大,它可能就覺(jué)得很占資源,且耗時(shí)。

其實(shí)不然,ST這么設(shè)計(jì)是有他一定的道理的,對(duì)于開(kāi)發(fā)大型、復(fù)雜系統(tǒng)的朋友而言,這條語(yǔ)句其實(shí)用處很大。每次,程序運(yùn)行錯(cuò)誤之后,它會(huì)打印程序代碼指定的位置,方便我們?cè)邶嫶蟮某绦蛑泻芸煺业藉e(cuò)誤的位置。

2.我們的系統(tǒng)會(huì)隨著時(shí)間的推移,不斷升級(jí)更新,也就是需要提交很多版本的可執(zhí)行文件(hex、bin等)。但是,產(chǎn)品后期使用中,我們對(duì)某些設(shè)備進(jìn)行了升級(jí),可能忽略了一些設(shè)備,也就是有些設(shè)備沒(méi)有升級(jí),如果出現(xiàn)故障,我們?cè)鯓硬拍芎芸煺业绞悄囊粋€(gè)版本的軟件出現(xiàn)故障呢?

這里就需要我們?cè)诔绦蛑刑砑右恍╆P(guān)于版本的信息,我們最基礎(chǔ)的就是Vx.x.x.x等這種信息,但對(duì)于大型系統(tǒng)而言,這種信息是不夠的,還需要更多,比如:編譯日期,時(shí)間,編譯環(huán)境的版本等。

Ⅱ幾種特殊標(biāo)準(zhǔn)定義

上面說(shuō)了這么多,就是需要讓大家知道,這些特殊標(biāo)準(zhǔn)定義的用途。上面說(shuō)的只是簡(jiǎn)單的舉例,其實(shí)他們的用途還很廣泛,掌握了基礎(chǔ)之后相信你們都會(huì)知道它們更多比較實(shí)用的意義。言歸正傳,下面講述這些基礎(chǔ)的知識(shí)。

本文主要講述下面幾個(gè)標(biāo)準(zhǔn)定義:

__LINE__:正在編譯文件的行號(hào)

__FILE__:正在編譯文件的文件名

__DATE__:編譯時(shí)刻的日期字符串 如“Jun 17 2017”

__TIME__:編譯時(shí)刻的時(shí)間字符串 如”1000“

__STDC__:判斷該文件是不是標(biāo)準(zhǔn)C程序

1.__FILE__編譯文件名稱

File中文意思即文件,這里的意思主要是指:正在編譯文件對(duì)應(yīng)正在編譯文件的路徑和文件的名稱。

Keil版本對(duì)應(yīng)的路徑是相對(duì)于工程文件而言的路徑,IAR版本路徑是相對(duì)Windows路徑。

比如下面提供源代碼工程:

char BuildFile[] = __FILE__;

printf("編譯文件路徑:%s\n", BuildFile);

Keil:

編譯文件路徑:App\main.c

IAR:

編譯文件路徑:C:\Users\Administrator\Desktop\STM32F417ZG(IAR)_ANSIC幾種特殊的標(biāo)準(zhǔn)定義\App\main.c

2.__LINE__編譯文件行號(hào)

上面說(shuō)的是編譯的文件名,是一個(gè)字符串,而這里說(shuō)的是行號(hào),是一個(gè)整型變量,這是這兩者的區(qū)別,所以在我提供工程中可以看到的源代碼:

char BuildLine = __LINE__;

printf("編譯代碼所在行:%d\n", BuildLine);

可以看不是數(shù)組的字符串,打印信息:

編譯代碼所在行:44

一般情況下,__FILE__是和__LINE__結(jié)合一起使用,用于打印我們代碼信息,方便快速定位代碼位置。

3.__DATE__編譯日期

__DATE__日期,需要注意的是:這個(gè)日期是你在編譯時(shí)Windows系統(tǒng)的日期,如果對(duì)應(yīng)那部分代碼之前編譯好了,后面沒(méi)有編譯,這個(gè)日期還是之前的日期,而不是后面編譯的日期。因此,如果這里用于定版本,就需要在定版本時(shí)對(duì)工程進(jìn)行全部重新編譯,它才會(huì)更新至你最后編譯的日期。

代碼:

char BuildDate[] = __DATE__;

printf("編譯日期:%s\n", BuildDate);

輸出結(jié)果:

編譯日期:Jun 17 2017

4.__TIME__編譯時(shí)間

這個(gè)和__DATE__一樣的原理,編譯時(shí)的時(shí)間,也是一個(gè)字符串。

再次提醒:用于定版本:需要重新編譯,這樣才是最后一次編譯時(shí)間。

代碼:

char BuildTime[] = __TIME__;

printf("編譯時(shí)間:%s\n", BuildTime);

輸出結(jié)果

編譯時(shí)間:1115

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代碼文件\n");

#else

printf("非標(biāo)準(zhǔn)C代碼文件\n");

#endif

Ⅲ源代碼分析與下載

為了方便大家學(xué)習(xí),本文提供的源代碼比較基礎(chǔ)和簡(jiǎn)單,也方便理論結(jié)合實(shí)際學(xué)習(xí),僅供參考。

我們?cè)谥靶陆ê玫腄emo工程上添加了如下部分代碼:

char BuildLine = __LINE__;

char BuildFile[] = __FILE__;

char BuildDate[] = __DATE__;

char BuildTime[] = __TIME__;

printf("編譯文件路徑:%s\n", BuildFile);

printf("編譯代碼所在行:%d\n", BuildLine);

printf("編譯日期:%s\n", BuildDate);

printf("編譯時(shí)間:%s\n", BuildTime);

#ifdef __STDC__

printf("標(biāo)準(zhǔn)C代碼文件\n");

#else

printf("非標(biāo)準(zhǔn)C代碼文件\n");

#endif

Keil版本輸出結(jié)果:

編譯文件路徑:App\main.c

編譯代碼所在行:44

編譯日期:Jun 17 2017

編譯時(shí)間:1115

標(biāo)準(zhǔn)C代碼文件

IAR版本輸出結(jié)果:

編譯文件路徑:C:\Users\Administrator\Desktop\STM32F417ZG(IAR)_ANSIC幾種特殊的標(biāo)準(zhǔn)定義\App\main.c

編譯代碼所在行:44

編譯日期:Jun 17 2017

編譯時(shí)間:1100

標(biāo)準(zhǔn)C代碼文件

源代碼工程(STM32F417ZG_ANSIC幾種特殊的標(biāo)準(zhǔn)定義)下載地址:

http://pan.baidu.com/s/1hskScba

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 單片機(jī)
    +關(guān)注

    關(guān)注

    6030

    文章

    44491

    瀏覽量

    632014
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5295

    瀏覽量

    119824
  • ANSIC
    +關(guān)注

    關(guān)注

    0

    文章

    6

    瀏覽量

    8663
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    室內(nèi)精準(zhǔn)定位的應(yīng)用范圍?室內(nèi)精準(zhǔn)定位的方式有哪些

    什么是室內(nèi)精準(zhǔn)定位?簡(jiǎn)單來(lái)講就是根據(jù)定位功能,實(shí)現(xiàn)室內(nèi)詳細(xì)的布局,然后利用這一功能去確定到精準(zhǔn)的位置。隨著我國(guó)科技水平的發(fā)展迅猛,定位系統(tǒng)也從曾經(jīng)初級(jí)的簡(jiǎn)單定位發(fā)展到了如今的精準(zhǔn)定位,取得了重大
    的頭像 發(fā)表于 07-11 11:52 ?357次閱讀
    室內(nèi)精<b class='flag-5'>準(zhǔn)定</b>位的應(yīng)用范圍?室內(nèi)精<b class='flag-5'>準(zhǔn)定</b>位的方式有哪些

    室內(nèi)精準(zhǔn)定位是什么?室內(nèi)精準(zhǔn)定位的方式有哪些?

    說(shuō)到室內(nèi)精準(zhǔn)定位很多人可能會(huì)比較陌生,因?yàn)檫@一說(shuō)法并沒(méi)有大范圍推廣,又或者說(shuō)只是很多相關(guān)行業(yè)的人才知道這樣的說(shuō)法。但是定位這一問(wèn)題大家都知道吧?尤其是要到一個(gè)地方去,都會(huì)進(jìn)行定位導(dǎo)航。那么這一般都是
    的頭像 發(fā)表于 07-09 16:30 ?440次閱讀

    app \"espsoftap\"如何使用自定義數(shù)據(jù)?

    ;esp_prov.py\", line 440, inif not custom_data(obj_transport, obj_security, args.custom_data):File
    發(fā)表于 06-24 07:57

    網(wǎng)絡(luò)跳線的標(biāo)準(zhǔn)有哪幾種

    網(wǎng)絡(luò)跳線的標(biāo)準(zhǔn)主要有以下幾種: 雙絞線標(biāo)準(zhǔn):雙絞線分為屏蔽雙絞線(STP)和非屏蔽雙絞線(UTP)兩種類(lèi)型。其中,Cat5e是最基本的雙絞線標(biāo)準(zhǔn),而Cat6、Cat6a、Cat7和Ca
    的頭像 發(fā)表于 06-14 10:42 ?747次閱讀

    stm32h745的特殊引腳如何使用HAL庫(kù)重定義

    現(xiàn)在手上有塊stm32h745ii的板子,想把pc13 pc14 pc15三個(gè)特殊引腳重定義為普通io口,找了一下HAL庫(kù),好像沒(méi)有f4庫(kù)里面能直接調(diào)用的接口,有知道的大神麻煩告知一下該如何操作
    發(fā)表于 05-24 08:31

    請(qǐng)問(wèn)CAN數(shù)據(jù)域的數(shù)據(jù)格式該如何定義?以什么標(biāo)準(zhǔn)定義?

    最近需要實(shí)現(xiàn)上位機(jī)與下位機(jī)的CAN通訊,現(xiàn)在雙方苦于不知該如何定義數(shù)據(jù)格式,尤其是傳輸浮點(diǎn)數(shù)據(jù)~~ 起初經(jīng)過(guò)討論直接根據(jù)個(gè)人主觀意愿定義了雙方的數(shù)據(jù)協(xié)議,,,其后,boss要求采用標(biāo)準(zhǔn)進(jìn)行定義
    發(fā)表于 05-09 07:20

    MC SDK5.0導(dǎo)致電機(jī)運(yùn)行時(shí)驅(qū)動(dòng)管發(fā)熱嚴(yán)重,定時(shí)器deadtime設(shè)置為0怎么解決?

    ) != HAL_OK) { _Error_Handler(__FILE__, __LINE__); } 我的修改方法是main.c中包含頭文件parameters_conversion.h
    發(fā)表于 04-29 08:43

    如何用cubemx做lin通信?

    ; if (HAL_LIN_Init( huart3, UART_LINBREAKDETECTLENGTH_11B) != HAL_OK) { _Error_Handler(__FILE__, __LINE__); } }
    發(fā)表于 04-26 07:44

    STM32H743 UART DMA數(shù)據(jù)發(fā)送報(bào)錯(cuò)的原因?

    = UART_ADVFEATURE_NO_INIT; if (HAL_UART_Init( huart4) != HAL_OK) { _Error_Handler(__FILE__, __LINE__); } } void
    發(fā)表于 04-26 06:59

    虛擬串口與STM32通信遇到的疑問(wèn)求解

    ; if (HAL_RCC_ClockConfig( RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK) { _Error_Handler(__FILE__, __LINE__
    發(fā)表于 04-24 08:29

    主循環(huán)里不斷開(kāi)啟關(guān)閉ADC的DMA傳輸功能,上電有幾率死機(jī)怎么解決?

    ; if (HAL_ADC_ConfigChannel( hadc1,sConfig) != HAL_OK) _Error_Handler(__FILE__, __LINE__); for(i = 0; i &
    發(fā)表于 04-23 07:20

    STM32F0 ADC多通道單次轉(zhuǎn)換,最后一個(gè)通道的EOC不置位是為什么?

    = ADC_OVR_DATA_PRESERVED; if (HAL_ADC_Init( hadc) != HAL_OK) { _Error_Handler(__FILE__, __LINE__); } sConfig.Channel
    發(fā)表于 04-16 06:34

    STM32F103VET6使用定時(shí)器DMA做比較輸出PWM,輸出波形第一次不正確是怎么回事?

    ) { Error_Handler(__FILE__, __LINE__); } sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL
    發(fā)表于 03-28 07:27

    美國(guó)FCC最新標(biāo)準(zhǔn)(HAC 2019),2023年12月5日起實(shí)施

    根據(jù)美國(guó)聯(lián)邦通信委員會(huì)(簡(jiǎn)稱FCC)的要求,從2023年12月5日開(kāi)始,手持終端設(shè)備必須符合ANSIC63.19-2019標(biāo)準(zhǔn)(也稱為HAC2019標(biāo)準(zhǔn))。根據(jù)最新發(fā)
    的頭像 發(fā)表于 12-06 15:17 ?1894次閱讀
    美國(guó)FCC最新<b class='flag-5'>標(biāo)準(zhǔn)</b>(HAC 2019),2023年12月5日起實(shí)施

    話題通信接口的定義和運(yùn)行效果

    ,將驅(qū)動(dòng)相機(jī)并發(fā)布圖像話題,此時(shí)的話題數(shù)據(jù)使用的是ROS中標(biāo)準(zhǔn)定義的Image圖像消息; 第二個(gè)節(jié)點(diǎn),會(huì)運(yùn)行視覺(jué)識(shí)別功能,識(shí)別目標(biāo)的位置,這個(gè)位置我們希望封裝成話題消息,發(fā)布出去,誰(shuí)需要使用誰(shuí)就來(lái)訂閱; 第三個(gè)節(jié)點(diǎn),訂閱位
    的頭像 發(fā)表于 12-01 15:32 ?405次閱讀
    話題通信接口的<b class='flag-5'>定義</b>和運(yùn)行效果