C语言如何使用宏定义封装printf等函数并且接收可变参数?编译预处理符号##的两种用途

本文介绍了如何通过C语言的宏定义和预处理器操作实现动态控制日志输出级别,模仿Linux内核的多级别log机制,以及使用`##args`处理可变参数。通过实例展示了宏定义的使用和预处理阶段参数替换的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景

平时代码日志一般Linux用户态使用printf,内核态使用printk,以及其他平台不同的日志。该方式如果需要动态控制日志的输出级别以及模块要移植到不同平台直接使用模块。如何解决这个问题,使用自定义的日志函数

自定义日志

如何自定义日志?可以通过宏定义 也可以定义独立函数。独立函数会带来一些性能损耗。所以最好用宏定义方式。
使用宏定义方式存在一个问题,就是比如printf很多时候的参数是可变的,那么如何使用宏定义支持将可变的参数能够支持

下面是模仿linux kernel的多级别log的方式

#define MY_MODULE_NAME "MY_MODULE_NAME"


#define MY_PRINT_LEVEL_DBG 7
#define MY_PRINT_LEVEL_INFO 6
#define MY_PRINT_LEVEL_NOTICE 5
#define MY_PRINT_LEVEL_WARNING 4
#define MY_PRINT_LEVEL_ERR 4
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值