一起來(lái)看看C語(yǔ)言的預(yù)處理注意點(diǎn)
C 預(yù)處理器
C 預(yù)處理器不是編譯器的組成部分,但是它是編譯過(guò)程中一個(gè)單獨(dú)的步驟。簡(jiǎn)言之,C 預(yù)處理器只不過(guò)是一個(gè)文本替換工具而已,它們會(huì)指示編譯器在實(shí)際編譯之前完成所需的預(yù)處理。
| 指令 | 描述 |
|---|---|
#define | 定義宏 |
#include | 包含一個(gè)源代碼文件 |
#undef | 取消已定義的宏 |
#ifdef | 如果宏已經(jīng)定義,則返回真 |
#ifndef | 如果宏沒(méi)有定義,則返回真 |
#if | 如果給定條件為真,則編譯下面代碼 |
#else | #if的替代方案 |
#elif | 如果前面的 #if 給定條件不為真,當(dāng)前條件為真,則編譯下面代碼 |
#endif | 結(jié)束一個(gè) #if……#else 條件編譯塊 |
#error | 當(dāng)遇到標(biāo)準(zhǔn)錯(cuò)誤時(shí),輸出錯(cuò)誤消息 |
#pragma | 使用標(biāo)準(zhǔn)化方法,向編譯器發(fā)布特殊的命令到編譯器中 |
1.取消已定義宏
demo.h文件代碼如下
#ifndef __DEMO_H_ #define __DEMO_H_ #define PAI 3.14 #endif // __DEMO_H_
#include <stdio.h>
#include "demo.h"
/* 在 #include 與 main 函數(shù)中間區(qū)域使用#undef來(lái)取消以定義的宏,然后重新定義宏 */
#undef PAI
#define PAI 33.14
int main()
{
printf("PAI = %G\n", PAI);
}
/*
輸出結(jié)果
PAI = 33.14
*/
2.使用#ifdef來(lái)調(diào)試
#ifdef DEBUG /* 你的調(diào)試代碼 */ #endif // DEBUG
如果定義了 DEBUG,則執(zhí)行處理語(yǔ)句。在編譯時(shí),如果您向 gcc 編譯器傳遞了 -DDEBUG 開(kāi)關(guān)量,這個(gè)指令就非常有用。它定義了 DEBUG,您可以在編譯期間隨時(shí)開(kāi)啟或關(guān)閉調(diào)試。
常用預(yù)定義宏
| 宏 | 描述 |
|---|---|
__DATE__ | 當(dāng)前日期,一個(gè)以 “MMM DD YYYY” 格式表示的字符常量。 |
__TIME__ | 當(dāng)前時(shí)間,一個(gè)以 “HH:MM:SS” 格式表示的字符常量。 |
__FILE__ | 這會(huì)包含當(dāng)前文件名,一個(gè)字符串常量。 |
__LINE__ | 這會(huì)包含當(dāng)前行號(hào),一個(gè)十進(jìn)制常量。 |
預(yù)處理器運(yùn)算符
1.宏延續(xù)運(yùn)算符
\一個(gè)宏通常寫(xiě)在一個(gè)單行上。但是如果宏太長(zhǎng),一個(gè)單行容納不下,則使用宏延續(xù)運(yùn)算符\
#include <stdio.h>
#define PAI \
3.1415926
int main()
{
printf("%.8f\n", PAI);
}
2.字符串常量化運(yùn)算符#
在宏定義中,當(dāng)需要把一個(gè)宏的參數(shù)轉(zhuǎn)換為字符串常量時(shí),則使用字符串常量化運(yùn)算符#。在宏中使用的該運(yùn)算符有一個(gè)特定的參數(shù)或參數(shù)列表。就是把宏的參數(shù)變成字符串。
#include <stdio.h>
#define PAI 3.1415926
//字符串常量化
#define CONVERT_TO_STR1(arg) "字符串常量化:" #arg
//字符串常量化
#define CONVERT_TO_STR2(arg) CONVERT_TO_STR1(arg)
int main()
{
printf("%s\n", CONVERT_TO_STR1(ABC));
printf("%s\n", CONVERT_TO_STR1(PAI));
printf("%s\n", CONVERT_TO_STR2(PAI));
}
/*
輸出結(jié)果
字符串常量化:ABC
字符串常量化:PAI
字符串常量化:3.1415926
*/
這里有幾點(diǎn)需要提一下。
1.宏定義中,當(dāng)有多個(gè)字符串需要連接時(shí),以空格來(lái)隔開(kāi)每一個(gè)字符串即可。
2.當(dāng)需要把一個(gè)宏字符串常量化時(shí),需要按照先定義一個(gè)宏函數(shù)1,然后再定義一個(gè)宏函數(shù)2,然后宏函數(shù)2調(diào)用宏函數(shù)1即可,例如CONVERT_TO_STR2調(diào)用CONVERT_TO_STR1
3.標(biāo)記粘貼運(yùn)算符##
宏定義內(nèi)的標(biāo)記粘貼運(yùn)算符(##)會(huì)合并兩個(gè)參數(shù)。它允許在宏定義中兩個(gè)獨(dú)立的標(biāo)記被合并為一個(gè)標(biāo)記。
#include <stdio.h>
#define PRINTF1(arg) printf("var" #arg " = %d\n" , var##arg)
int main()
{
int var1 = 20;
PRINTF1(1);
}
/*
輸出結(jié)果
var1 = 20
*/
參數(shù)化的宏
使用注意點(diǎn)
用宏定義時(shí),含參數(shù)時(shí),參數(shù)本身要加(),此外,對(duì)參數(shù)的操作整體也要加()。
#define MAX(a,b) ((a)>(b)?(a):(b))
使用宏函數(shù)的時(shí)候不要使用++/--運(yùn)算符
#include <stdio.h>
#define MIN(A,B) ((A)<(B)?(A):(B))
int main()
{
char *p="ghi";
char a;
a=MIN(*p++,'f');//不要使用自增/自減運(yùn)算符
printf("%c\n",a);
}
/*
輸出結(jié)果
f
*/
另,宏定義實(shí)現(xiàn)指定大小的交換:
#define SWAP(a, b, size) \
unsigned int __size = (size); \
char *__a = (a), *__b = (b); \
do \
{ \
char __tmp = *__a; \
*__a++ = *__b; \
*__b++ = __tmp; \
} while (--__size > 0);
總結(jié)
本篇文章就到這里了,希望能夠給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
Qt數(shù)據(jù)庫(kù)應(yīng)用之實(shí)現(xiàn)通用數(shù)據(jù)生成器
有兩種應(yīng)用場(chǎng)景需要用到數(shù)據(jù)生成器,一種是需要測(cè)試數(shù)據(jù)庫(kù)性能,一種是隨機(jī)模擬生成一堆數(shù)據(jù),用來(lái)測(cè)試程序的性能。本文將利用Qt實(shí)現(xiàn)通用數(shù)據(jù)生成器,需要的可以參考一下2022-02-02
C++實(shí)現(xiàn)LeetCode(67.二進(jìn)制數(shù)相加)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(67.二進(jìn)制數(shù)相加),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
C++11并發(fā)編程關(guān)于原子操作atomic的代碼示例
今天小編就為大家分享一篇關(guān)于C++11并發(fā)編程關(guān)于原子操作atomic的代碼示例,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2018-12-12
C語(yǔ)言實(shí)現(xiàn)排序算法之歸并排序詳解
這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)排序算法之歸并排序,對(duì)歸并排序的原理及實(shí)現(xiàn)過(guò)程做了非常詳細(xì)的解讀,需要的朋友可以參考下2014-07-07
C語(yǔ)言實(shí)現(xiàn)圖書(shū)管理系統(tǒng)課程設(shè)計(jì)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)圖書(shū)管理系統(tǒng)課程設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07
undefined reference to `SetPduPowerConsumptionCnt''錯(cuò)誤的解決方法
編譯時(shí)出現(xiàn)undefined reference to `SetPduPowerConsumptionCnt'錯(cuò)誤要如何解決呢?有沒(méi)有什么好的解決方法?下面小編就為大家解答吧,如果你也遇到了這種情況,可以過(guò)來(lái)參考下2013-07-07
C++動(dòng)態(tài)內(nèi)存分配(new/new[]和delete/delete[])詳解
這篇文章主要介紹了C++動(dòng)態(tài)內(nèi)存分配(new/new[]和delete/delete[])詳解的相關(guān)資料,需要的朋友可以參考下2017-05-05

