嵌入式C语言——设计调试宏

前言

借调试宏的设计,梳理下宏的用法

重定向printf打印

嵌入式设备基本会配置RS232串口作为调试IO接口,假设底层串口单字节输出函数为SERIAL_PutChar(),利用fputc()fputs()重定向printf函数

	void fputc(int byte, FILE* stream)
	{
		(void)stream;
	
		SERIAL_PutChar(byte);
	}
	
	void fputs(const char *pstr, FILE *stream)
	{
		(void)stream;
	
		while(*pstr)
		{
			SERIAL_PutChar(*pstr++);
		}
	}

这样在代码里面利用printf()函数输出的字符串都老老实实从调试串口出来

调试宏使用场景

某个C驱动模块,希望在调试时打印调试信息,而产品代码中不显示调试信息。

V1-单参数宏

	#define DRV_DEBUG 1
	#if DRV_DEBUG
		#define DRV_PRINT(x) printf(x)
	#else
		#define DRV_PRINT(x) 
	#endif

这个版本的DRV_PRINT(x)只能输出单变量——纯字符串

	void foo()
	{
		DRV_PRINT("Driver Initialize Success!");
	}

不需要打印调试信息时,更改DRV_DEBUG宏定义

	#define DRV_DEBUG 0

当然也可以直接这样定义

	#define DRV_PRINT printf

但是如果宏调用了多个参数:

	void foo()
	{
		DRV_PRINT("Driver Initialize Success: ver %d.%d !", 1, 2);
	}

产品代码中的#define DRV_PRINT(x) 将编译错误!

怎么办?一种处女座接受不了的做法,多加对括号

	void foo()
	{
		DRV_PRINT(("Driver Initialize Success: ver %d.%d !", 1, 2));
	}

不管是调试代码还是产品代码,编译都OK

v2-指定参数宏

待续

v3-参数数量可变宏

待续

转载于:https://my.oschina.net/codeinsight/blog/214466

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值