程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> C語言中宏定義#define用法總結

C語言中宏定義#define用法總結

編輯:關於C語言

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;

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved