條件編譯的用法
[cpp]view plaincopy
- #ifndef__USART_H
- #define__USART_H
- #include
- #include"stdio.h"
- externu8USART_RX_BUF[64];//接收緩沖,最大63個(gè)字節(jié).末字節(jié)為換行符
- externu8USART_RX_STA;//接收狀態(tài)標(biāo)記
- //如果想串口中斷接收,請(qǐng)不要注釋以下宏定義
- //#defineEN_USART1_RX//使能串口1接收
- voiduart_init(u32pclk2,u32bound);
- #endif
這段程序里#define EN_USART1_RX被注釋掉了。
usart.c里有一段串口中斷響應(yīng)子函數(shù)程序如下:
[cpp]view plaincopy
- #ifdefEN_USART1_RX//如果使能了接收
- u8USART_RX_BUF[64];//接收緩沖,最大64個(gè)字節(jié).
- u8USART_RX_STA=0;//接收狀態(tài)標(biāo)記
- voidUSART1_IRQHandler(void)
- {
- ......
- }
- #endif
手冊(cè)給出的解釋是,這里用了宏定義#ifdef,當(dāng)需要使用串口接收的時(shí)候,只要在usart.h里面定義EN_USART1_RX就可以了。不使用的時(shí)候注釋掉就可,這樣可以省出部分sram和flash。
下轉(zhuǎn)一篇文章:http://blog.163.com/solylee@126/blog/static/171823157201011914824753/
C中#if 0 和#if 1
當(dāng)注釋掉大塊代碼時(shí),使用"#if 0"比使用"/**/"要好,因?yàn)橛?/**/"做大段的注釋要防止被注釋掉的代碼中有嵌套的"/**/",這會(huì)導(dǎo)致注釋掉的代碼區(qū)域不是你想要的范圍, 當(dāng)被注釋掉的代碼很大時(shí)容易出現(xiàn)這種情況,特別是過(guò)一段時(shí)間后又修改該處代碼時(shí)更是如此。
在這里順便對(duì)條件編譯(#ifdef, #else, #endif, #if等)進(jìn)行說(shuō)明。以下分3種情況: 1. 情況1: #ifdef _XXXX ...程序段1... #else ...程序段2... #endif 這表明如果標(biāo)識(shí)符_XXXX已被#define命令定義過(guò)則對(duì)程序段1進(jìn)行編譯;否則對(duì)程序段2進(jìn)行編譯?! ±? #define NUM ............. ............. ............. #ifdef NUM printf("之前NUM有過(guò)定義啦!:) "); #else printf("之前NUM沒有過(guò)定義!:( "); #endif } 如果程序開頭有#define NUM這行,即NUM有定義,碰到下面#ifdef NUM的時(shí)候,當(dāng)然執(zhí)行第一個(gè)printf。否則第二個(gè)printf將被執(zhí)行?! ∥艺J(rèn)為,用這種,可以很方便的開啟/關(guān)閉整個(gè)程序的某項(xiàng)特定功能?! ?:情況2: #ifndef _XXXX ...程序段1... #else ...程序段2... #endif 這里使用了#ifndef,表示的是if not def。當(dāng)然是和#ifdef相反的狀況(如果沒有定義了標(biāo)識(shí)符_XXXX,那么執(zhí)行程序段1,否則執(zhí)行程序段2)。例子就不舉了?! ?:情況3: #if 常量 ...程序段1... #else ...程序段2... #endif 這里表示,如果常量為真(非0,隨便什么數(shù)字,只要不是0),就執(zhí)行程序段1,否則執(zhí)行程序段2。如果有#if需要頂格寫
評(píng)論