#include <stdio.h>
#include <stdlib.h>
#define global_debug 2
#define global_progname "MYLOG"
enum
{
ERROR,
WARN,
INFO,
DEBUG,
};
#define debug(OUT, STR, ARGS...) \
if (global_debug >= DEBUG) \
fprintf(stdout, "%s - DEBUG: [%lli] ", global_progname, (long long)getpid()),\
fprintf(OUT, STR, ##ARGS), fflush(OUT)
#define info(OUT, STR, ARGS...) \
if (global_debug >= INFO) \
fprintf(stdout, "%s - INFO: [%lli] ", global_progname, (long long)getpid()),\
fprintf(OUT, STR, ##ARGS), fflush(OUT)
#define warn(OUT, STR, ARGS...) \
if (global_debug >= WARN) \
fprintf(stdout, "%s - WARN: [%lli] (line: %d) ", global_progname, (long long)getpid(),__LINE__ ),\
fprintf(OUT, STR, ##ARGS), fflush(OUT)
#define error(OUT, STR, ARGS...) \
if (global_debug >= ERROR) \
fprintf(stdout, "%s - ERROR: [%lli](line: %d) ", global_progname, (long long)getpid(), __LINE__),\
如何在程序中写log日志(定义log级别:error,warn, info, debug; 宏定义打印不同级别的日志; 程序中引用宏定义即可)
最新推荐文章于 2024-08-16 07:15:40 发布
本文档展示了如何在C程序中定义和使用日志级别(ERROR、WARN、INFO、DEBUG),通过宏定义实现不同级别的日志打印。示例中详细解释了debug、info、warn和error宏的用法,并在main函数中给出了实际应用例子。
摘要由CSDN通过智能技术生成