使用宏定义可以防止出错,提高可移植性,可读性,方便性等。
下面列举了一些成熟软件中常用的宏定义。
重新定义一些类型,防止由于各种平台和编译器的不同,而产生的类型字节数差异,方便移植:
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 */
求最大值和最小值:
#define MAX( x, y ) ( ((x) > (y)) ? (x) : (y) ) #define MIN( x, y ) ( ((x) < (y)) ? (x) : (y) )
得到一个field在结构体(struct)中的偏移量:
#define FPOS( type, field ) /*lint -e545 */ ( (dword) &(( type *) 0)-> field ) /*lint +e545 */
得到一个结构体中field所占用的字节数:
#define FSIZ( type, field ) sizeof( ((type *) 0)->field )
按照LSB格式把两个字节转化为一个Word:
1#define FLIPW( ray ) ( (((word) (ray)[0]) * 256) + (ray)[1] )
按照LSB格式把一个Word转化为两个字节:
#define FLOPW( ray, val ) (ray)[0] = ((val) / 256); (ray)[1] = ((val) & 0xFF)
得到一个变量的地址(word宽度):
#define B_PTR( var ) ( (byte *) (void *) &(var) ) #define W_PTR( var ) ( (word *) (void *) &(var) )
得到一个字的高位和低位字节:
#define WORD_LO(xxx) ((byte) ((word)(xxx) & 255)) #define WORD_HI(xxx) ((byte) ((word)(xxx) >> 8))
将一个字母转换为大写:
#define UPCASE( c ) ( ((c) >= 'a' && (c) <= 'z') ? ((c) - 0x20) : (c) )
判断字符是不是10进制的数字:
#define DECCHK( c ) ((c) >= '0' && (c) <= '9')
判断字符是不是16进制的数字:
#define HEXCHK( c ) ( ((c) >= '0' && (c) <= '9') || ((c) >= 'A' && (c) <= 'F') || ((c) >= 'a' && (c) <= 'f') )
防止一个头文件被重复包含:
#ifndef COMDEF_H #define COMDEF_H //头文件内容 #endif
防止溢出的一个方法:
#define INC_SAT( val ) (val = ((val)+1 > (val)) ? (val)+1 : (val))
返回数组元素的个数:
#define ARR_SIZE( a ) ( sizeof( (a) ) / sizeof( (a[0]) ) )
审核编辑:刘清
全部0条评论
快来发表一下你的评论吧 !