背景
平时代码日志一般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