宏定義多條語句
宏定義多條語句可以用如下的形式進行定義: #define swap(a,b) { a = a + b; b = a - b; a = a - b; }// 如果分行寫,可以寫成如下形式#define swap(a,b) { a = a + b;\b = a - b;\a = a - b;} 宏定義一般分為帶參宏定義和不帶參宏定義。
帶參宏定義,也即帶參數的宏定義,如: #define MAX(a,b) ((a)>(b) ? (a) : (b)) // 求最大值不帶參宏定義,也即不帶參數的宏定義,如: #define PI 3.14159 // 定義圓周率pi的值。
宏定義多條語句
宏定義多條語句可以用如下的形式進行定義:
#define swap(a,b) { a = a + b; b = a - b; a = a - b; }
// 如果分行寫,可以寫成如下形式
#define swap(a,b) { a = a + b;\
b = a - b;\
a = a - b;}
宏定義一般分為帶參宏定義和不帶參宏定義。
帶參宏定義,也即帶參數的宏定義,如:
#define MAX(a,b) ((a)>(b) ? (a) : (b)) // 求最大值不帶參宏定義,也即不帶參數的宏定義,如:
#define PI 3.14159 // 定義圓周率pi的值
一個C語言的宏定義語句
#define WRITE(DATATYPE,DATA) do{*(DATATYPE*)(save_offset)=DATA;save_offset +=sizeof(DATATYPE);}while(0)
我建議宏這樣寫比較好,可以避免很多麻煩。
save_offset 是unsigned int型。意思是存放指針地址數據的地方,不是指針類型,是你所說的普通變量,0-65535之間(我取的是2個字節所以是2的16次方 - 1,但不一定是這個數,根據編譯器不同而不同)。
DATATYPE 是變量類型 譬如 int ,char型。
(DATATYPE*)(save_offset) 強制轉換為DATATYPE類型指針;*(DATATYPE*)(save_offset)意思是在0x0000地址寫入DATA。
save_offset +=sizeof(DATATYPE) 這句話意思是 save_offset取下一個地址。
這個宏定義的主要功能是 在0x0000開頭的內存中寫入DATATYPE數據。
例如:
WRITE(char,128);
宏展開之后是:
do{*(char*)(save_offset)=128;save_offset +=sizeof(char);}while(0)
執行過后
在內存地址為0x0000處寫入數據128占據sizeof(char)個字節,并在0x0000 + sizeof(char)處等待下一個數據的寫入。
大概就是這個意思。
單片機c語言宏定義有幾種
宏定義 宏定義是C提供的三種預處理功能的其中一種,這三種預處理包括:宏定義、文件包含、條件編譯 編輯本段1.不帶參數的宏定義: 宏定義又稱為宏代換、宏替換,簡稱“宏”。
格式: #define 標識符 字符串 其中的標識符就是所謂的符號常量,也稱為“宏名”。 預處理(預編譯)工作也叫做宏展開:將宏名替換為字符串。
掌握"宏"概念的關鍵是“換”。一切以換為前提、做任何事情之前先要換,準確理解之前就要“換”。
即在對相關命令或語句的含義和功能作具體分析之前就要換: 例: #define PI 3.1415926 把程序中出現的PI全部換成3.1415926 說明: (1)宏名一般用大寫 (2)使用宏可提高程序的通用性和易讀性,減少不一致性,減少輸入錯誤和便于修改。例如:數組大小常用宏定義 (3)預處理是在編譯之前的處理,而編譯工作的任務之一就是語法檢查,預處理不做語法檢查。
(4)宏定義末尾不加分號; (5)宏定義寫在函數的花括號外邊,作用域為其后的程序,通常在文件的最開頭。 (6)可以用#undef命令終止宏定義的作用域 (7)宏定義可以嵌套 (8)字符串" "中永遠不包含宏 (9)宏定義不分配內存,變量定義分配內存。
編輯本段2.帶參數的宏定義: 除了一般的字符串替換,還要做參數代換 格式: #define 宏名(參數表) 字符串 例如:#define S(a,b) a*b area=S(3,2);第一步被換為area=a*b; ,第二步被換為area=3*2; 類似于函數調用,有一個啞實結合的過程: (1)實參如果是表達式容易出問題 #define S(r) r*r area=S(a+b);第一步換為area=r*r;,第二步被換為area=a+b*a+b; 正確的宏定義是#define S(r) ((r)*(r)) (2)宏名和參數的括號間不能有空格 (3)宏替換只作替換,不做計算,不做表達式求解 (4)函數調用在編譯后程序運行時進行,并且分配內存。宏替換在編譯前進行,不分配內存 (5)宏的啞實結合不存在類型,也沒有類型轉換。
(6)函數只有一個返回值,利用宏則可以設法得到多個值 (7)宏展開使源程序變長,函數調用不會 (8)宏展開不占運行時間,只占編譯時間,函數調用占運行時間(分配內存、保留現場、值傳遞、返回值C語言宏定義技巧(常用宏定義) 寫好C語言,漂亮的宏定義很重要,使用宏定義可以防止出錯,提高可移植性,可讀性,方便性 等等。下面列舉一些成熟軟件中常用得宏定義:1,防止一個頭文件被重復包含 #ifndef COMDEF_H #define COMDEF_H //頭文件內容 #endif 2,重新定義一些類型,防止由于各種平臺和編譯器的不同,而產生的類型字節數差異,方便移植。
typedef unsigned char boolean; /* Boolean value type. */ typedef unsigned long int uint32; /* Unsigned 32 bit value */ typedef unsigned short uint16; /* Unsigned 16 bit value */ typedef unsigned char uint8; /* Unsigned 8 bit value */ typedef signed long int int32; /* Signed 32 bit value */ typedef signed short int16; /* Signed 16 bit value */ typedef signed char int8; /* Signed 8 bit value */ 3,得到指定地址上的一個字節或字 #define MEM_B( x ) ( *( (byte *) (x) ) ) #define MEM_W( x ) ( *( (word *) (x) ) ) 4,求最大值和最小值 #define MAX( x, y ) ( ((x) > (y)) ? (x) : (y) ) #define MIN( x, y ) ( ((x) < (y)) ? (x) : (y) ) 5,得到一個field在結構體(struct)中的偏移量 #define FPOS( type, field ) \ /*lint -e545 */ ( (dword) &(( type *) 0)-> field ) /*lint +e545 */ 6,得到一個結構體中field所占用的字節數 #define FSIZ( type, field ) sizeof( ((type *) 0)->field ) 7,按照LSB格式把兩個字節轉化為一個Word #define FLIPW( ray ) ( (((word) (ray)[0]) * 256) + (ray)[1] ) 8,按照LSB格式把一個Word轉化為兩個字節 #define FLOPW( ray, val ) \ (ray)[0] = ((val) / 256); \ (ray)[1] = ((val) & 0xFF) 9,得到一個變量的地址(word寬度) #define B_PTR( var ) ( (byte *) (void *) &(var) ) #define W_PTR( var ) ( (word *) (void *) &(var) ) 10,得到一個字的高位和低位字節 #define WORD_LO(xxx) ((byte) ((word)(xxx) & 255)) #define WORD_HI(xxx) ((byte) ((word)(xxx) >> 8)) 11,返回一個比X大的最接近的8的倍數 #define RND8( x ) ((((x) + 7) / 8 ) * 8 ) 12,將一個字母轉換為大寫 #define UPCASE( c ) ( ((c) >= 'a' && (c) <= 'z') ? ((c) - 0x20) : (c) ) 13,判斷字符是不是10進值的數字 #define DECCHK( c ) ((c) >= '0' && (c) <= '9') 14,判斷字符是不是16進值的數字 #define HEXCHK( c ) ( ((c) >= '0' && (c) <= '9') ||\ ((c) >= 'A' && (c) <= 'F') ||\ ((c) >= 'a' && (c) <= 'f') ) 15,防止溢出的一個方法 #define INC_SAT( val ) (val = ((val)+1 > (val)) ? (val)+1 : (val)) 16,返回數組元素的個數 #define ARR_SIZE( a ) ( sizeof( (a) ) / sizeof( (a[0]) ) ) 17,返回一個。