如果有错误,欢迎下面留言评论
1.#字符串化
#的作用就是将#后边的宏参数进行字符串的操作,也就是将#后边的参数两边加上一对双引号使其成为字符串。例如a是一个宏的形参,则替换文本中的#a被系统转化为"a",这个转换过程即为字符串化。
#define TEST(param) #param
char *pStr=TEST(123);
printf("pSrt=%s\n",pStr);
输出结果:
pSrt=123
表示的意思是字符串123,这里的#xxx,可以是数字也可以是字母,反正都是字符串含义
2.##连接数字
##运算符也可以用在替换文本中,它的作用起到粘合的作用,即将两个宏参数连接为一个数
#define TEST(param1,param2) (param1##param2)
int num =TEST(13,59);
printf("num=%d\n",num);
输出结果:
num=1359
3.连接字符串
#define TEST(string) "123"string"456"
printf("%s\n",TEST("789"));
输出结果:
123789456
这里的"123"string"456"也可以是“abc”string“cde”
4.log可变参数
#define LOG_WARNING(psFmz, args...) bf_log_printf(s_ucLogId, LOG_L_WARNING, psFmz, ##args)
#define LOG_TRACE(psFmz, args...) bf_log_printf(s_ucLogId, LOG_L_TRACE, psFmz, ##args)
#define LOG_ERROR(psFmz, args...) bf_log_printf(s_ucLogId, LOG_L_ERROR, psFmz, ##args)
#define LOG_API(psFmz, args...) bf_log_printf(s_ucLogId, LOG_L_API, psFmz, ##args)
理解为有##可以有参无参,但是没有##无参会报错
5.防止一个头文件被重复包含
#ifndef COMDEF_H
#define COMDEF_H
//头文件内容
#endif
6.得到指定地址上的一个字节或字
#define MEM_B(x) (*((byte *)(x)))
#define MEM_W(x) (*((word *)(x)))
7.得到一个字的高位和低位字节
#define WORD_LO(xxx) ((byte) ((word)(xxx) & 255))
#define WORD_HI(xxx) ((byte) ((word)(xxx) >> 8))
返回数组元素的个数
#define ARR_SIZE(a) (sizeof((a))/sizeof((a[0])))
宏给结构体初始化
#include <stdio.h>
#define new_rect(length , width) {length , width}
struct rect{
int length;
int width;
};
int main()
{
struct rect rect1 = new_rect(10 , 5);
printf("%d , %d\n",rect1.length, rect1.width);
return 0;
}
编译结果:
10,5
在上面的demo基础上加点难度,添加函数指针成员
#include <stdio.h>
#define new_rect(length , width) {(calc_area), (length) , (width)}
struct rect{
int (*calc_area)(struct rect *pThis);
int length;
int width;
};
int calc_area(struct rect *pRect)
{
return (pRect->length) * (pRect->width);
}
int main()
{
struct rect rect1 = new_rect(10 , 5);
printf("rect_area = %d\n",rect1.calc_area(&rect1));
return 0;
}
编译结果:
rect_area = 50