C語言中define的用法總結
阿新 • • 發佈:2019-01-25
1.簡單的巨集定義
#define 識別符號 替換列表(替換列表可以是數,字串字面量,標點符號,運算子,識別符號,關鍵字,字元常量。注意:替換列表是可以為空的)
典型錯誤:
#define N = 100
int a[N]; /*這樣會成為int a[= 100],這裡會處理成為一種標識記號一樣*/
#define N 100;
int a[N]; /*帶分號的定義會成為int a[100;],這是一種很常見的錯誤*/
#define pin (int*);
pin a,b;
int* a,b; /*本意是a和b都是int型指標,但是實際上變成int* a,b;a是int型指標,而b是int型變數。這是應該使用typedef來代替define,這樣a和b就都是int型指標了。*/
典型的使用方法:
使用巨集定義我們可以自己根據自己的習慣來定義甚至改變C語言的語法習慣,例如:
#define BEGIN {
#define END }
int main()BEGIN
printf ("DEFINE----\n");
END
定義一個迴圈
#define LOOP for(;;)
重新定義資料型別
#define IT int
2.帶引數的巨集
#define 識別符號(x1,x2,x3...xn) 替換列表 (注意:x1,x2,x3..是巨集的引數,識別符號和其左括弧之間不能有空格)
使用方法:
#define MAX(x,y) ((x)>(y)?(x):(y))
i=MAX(j+k,m-n);
替換為:
i=MAX((j+k)>(m-n)?(j+k):(m-n));
#define SI_EX(n) ((n)%2==0)
if(SI_EX(i)) i++;
替換為:
if(SI_EX((i)%2==0))
通過以上例子我們可以看出,識別符號帶引數(X1,X2,X3.....)在替換時會被替換列表(Y1,Y2,Y3....)對應的替換,但是和順序無關。
3.巨集的特殊單行定義
#define A(x) T_##x
#define B(x) #@x
#define C(x) #x
x=1
替換為:
A(1)------> T_1 (T_##x,##符號是記號粘黏符號,將前後的字元粘黏起來。)
B(1)------> '1' ( #@x , #@ 符號會將巨集的引數進行字串字面量化,並且加‘’號)
C(1)------> "1" ( #x ,#符號會將巨集的引數進行字串字面量化,並且加""號)
4.define的多行定義
define可以替代多行的程式碼,在每一個換行的時候加上一個"\"
#define MAX(X,Y) do { \
語句1; \
語句2; \
/* 註釋的寫法 */ \
} while(0) /* (no trailing ; ) */ \
5.在大規模的開發過程中,特別是跨平臺和 系統的軟體裡,define最重要的功能是條件編譯。
#ifdef WINDOWS
......
......
#endif
#ifdef LINUX
......
......
#endif
可以在編譯的時候通過#define設定編譯環境
6.取消巨集
#undef 識別符號
7.條件編譯
#ifdef XXX…(#else) … #endif
8.預定義巨集
在C語言中收錄了一些有用的巨集,這些巨集是提供當前編譯資訊的。
__LINE__ 被編譯檔案的行數
(整型)
__FILE__ 被編譯檔案的名字 (字元型)
__DATE__ 編譯日期 (字元型)
__TIME__ 編譯時間 (字元型)
__STDC__ 如果編譯器接受標準C,那麼值為1. (整型)
通常我們在編譯的時候我們可以用這些預定義的巨集來進行排錯,例如:
一般情況下,當出現除零的情況時編譯器是沒有提示的,我們可以自定義一個解決辦法。
#define CHECKZERO(divisor)\
if(divisor==0)\
printf("***ATTEMPT TO DIVIDE BY ZERO IN LINE %d of file %s ***\n",__LINE__,__FILE__);\
引用方法
CHECKZERO(j);
k=i/j;