可变参数和vprintf以及#、##、__VA_ARGS__的作用

可变参数和vprintf以及#、##、__VA_ARGS__的作用

start
#include
#include

typedef enum log_level {
L_ALL = 0xFF, L_DEBUG = 0x01, L_WRING = 0x02, L_INFO = 0x04, L_ERR = 0x08
} LOG_LEVEL;

//#define log_d(format,…) log_printf(L_DEBUG,FILE,FUNCTION,LINE,format, VA_ARGS)
#define log_d(format,…) log_printf(L_DEBUG,FILE,FUNCTION,LINE,format, ##VA_ARGS)

static void _log_printf(const char *format, …) {
va_list ap;
va_start(ap, format);
vprintf(format, ap);
va_end(ap);
}

int log_printf(LOG_LEVEL _level, const char *file, const char *function,
int line, const char *format, …) {
int len = 0;
char timeStr[50];
struct tm *p;

va_list list;
va_start(list, format);

switch (_level) {
case L_DEBUG:
    _log_printf("-DEBUG:%s,%s,%d:", file, function, line);
    break;
case L_INFO:
    _log_printf("-INFO:%s,%s,%d:", file, function, line);
    break;
case L_WRING:
    _log_printf("-WRING:%s,%s,%d:", file, function, line);
    break;
case L_ERR:
    _log_printf("-ERR:%s,%s,%d:", file, function, line);
    break;
default:
    break;
}
vprintf(format, list);
printf("\n");
va_end(list);
fflush(stdout);
return len;

}

int main()
{
const char *commands = “wodkfkdf\n”;
int cc = 609;
log_d(“system->%s”, commands);
log_d(“cc ==%d\n”,cc);
//如果不是##VA_ARGS 此处就编译不过
//##VA_ARGS 宏前面加上##的作用在于,当可变参数的个数为0时,
//这里的##起到把前面多余的","去掉的作用,否则会编译出错
log_d(“dazhongguo”);

}

//end
#用来把参数转换成字符串
#define P(A) printf(“%s:%d\n”,#A,A)
##运算符可以用于宏函数的替换部分。这个运算符把两个语言符号组合成单个语言符号,为宏扩展提供了一种连接实际变元的手段,##就是个粘合剂
#define XNAME(n) x##n
XNAME(8) —>x8

VA_ARGS 是一个可变参数的宏
实现思想就是宏定义中参数列表的最后一个参数为省略号(也就是三个点)

##VA_ARGS 宏前面加上##的作用在于,当可变参数的个数为0时,这里的##起到把前面多余的","去掉的作用,否则会编译出错
举例
///start
#include
#include

//三种种写法
#define Printf(format,…) PPrintf(func,format,##VA_ARGS)
//下面写法编译不过
//#define Printf(format,…) PPrintf(func,format,VA_ARGS)
//#define Printf(…) PPrintf(func,VA_ARGS)

void PPrintf(char *func,char *format, …)
{
va_list ap;

printf("%s ",func);
va_start(ap, format);
vprintf(format, ap);
va_end(ap);

}

int main(void)
{
int jc = 50;
Printf(“jc ==%d\n”,jc);
Printf(“slslsl”);

}

/end

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xx-xx-xxx-xxx

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值