可变参数打印·

1.变参函数
对于变参函数,编译器或操作系统一般会提供一些宏给程序员使用,用来解析函数的参数列表,这样程序员就不用自己解析了,直接调用封装号的宏即可获取参数列表。编译器提供的宏有一下三种。
va_list: 定义再编译器头文件stdarg.h中
va_start(fmt,args):根据参数args的地址,获取args后面参数的地址,并保存再fmt指针变量中
va_end(args):释放args指针,并将其复制位NULL
例子:

 #include <stdio.h>
#include <stdarg.h>	/*需要包含此头文件*/


typedef unsigned char u8;

void __attribute__((format(printf,2,3))) debug_print(u8 level,char *fmt,...);	/* format指明编译器检查输入类型 */
#define DEBUG(level,...) debug_print(level,__VA_ARGS__)

void __attribute__((format(printf,2,3))) debug_print(u8 level,char *fmt,...)
{
if (level > 2)
{
va_list args;
va_start(args,fmt);
vprintf(fmt,args);
va_end(args);
}
}



int main()
{
int a=10;
int b=11;
char *str = "hello world\n";
char *str1= "hello\n";
DEBUG(1,"A = %d ,B= %d STR= %s",a,b,str);
DEBUG(3,"A = %d ,B= %d STR= %s",a,b,str1);
return 0;
}

结果如下:
root@xhao-virtual-machine:/home/xhao# gcc -o log log.c
root@xhao-virtual-machine:/home/xhao# ./log
A = 10 ,B= 11 STR= hello
root@xhao-virtual-machine:/home/xhao#

2.可变参数宏
C99支持了可变参数宏,以简化可变参数打印

#define PFB_DEBUG(level,fmt,...) do{if(DEBUG_LEVEL>level) printf(fmt,##__VA_ARGS__);}while(0)

PFB_DEBUG宏实现只有DEBUG_LEVEL大于level时才进行打印的功能
GNUC下可将__VA_ARGS__参数改写为args

#define PFB_DEBUG(level,fmt,...) do{if(DEBUG_LEVEL>level) printf(fmt,##args);}while(0)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值