1.概述
c語言沒有現成的日志庫,如果要記錄日志,需要自己封裝一個日志庫。如果要實現日志級別和參數打印,還是比較麻煩的,正好在github找到了一個c語言開源日志庫,可以實現日志級別打印,參數打印,而且還會記錄日期和行號,最重要的是代碼非常少,只有100多行,可以直接包含在我們自己的工程代碼中,不需要任何依賴。
2.源碼地址
GitCode - 全球開發者的開源社區,開源代碼托管平臺
3.使用介紹
3.1直接把工程目錄下的log.c和log.h下載下來,包含到工程代碼中即可,沒有其他依賴。
3.2日志級別由低到高,分別為 LOG_TRACE、LOG_DEBUG、LOG_INFO、LOG_WARN、LOG_ERROR、LOG_FATAL
3.3如果設置日志級別為LOG_TRACE,則所有級別日志都會打印,如果設置日志級別為LOG_WARN,則只會打印LOG_WARN以及更高級別(即LOG_ERROR和LOG_FATAL)的日志
4.測試代碼
log.c
#include "log.h"
#include <stdio.h>int main() {FILE *fp = fopen("log.txt", "a+");if(fp == NULL){printf("create log file failed.\n");return -1;}//設置日志級別(在終端打印)log_set_level(LOG_TRACE);//設置日志級別(在文件中打印)log_add_fp(fp, LOG_INFO);log_trace("start trace.");log_debug("start debug.");log_info("start info.");log_warn("start warn.");log_error("start error.");log_fatal("start fatal");// 支持參數打印log_info("number is %d, string is %s", 10010, "helloword");fclose(fp);
}
log.h
/*** Copyright (c) 2020 rxi** This library is free software; you can redistribute it and/or modify it* under the terms of the MIT license. See `log.c` for details.*/#ifndef LOG_H
#define LOG_H#include <stdio.h>
#include <stdarg.h>
#include <stdbool.h>
#include <time.h>#define LOG_VERSION "0.1.0"typedef struct {va_list ap;const char *fmt;const char *file;struct tm *time;void *udata;int line;int level;
} log_Event;typedef void (*log_LogFn)(log_Event *ev);
typedef void (*log_LockFn)(bool lock, void *udata);enum { LOG_TRACE, LOG_DEBUG, LOG_INFO, LOG_WARN, LOG_ERROR, LOG_FATAL };#define log_trace(...) log_log(LOG_TRACE, __FILE__, __LINE__, __VA_ARGS__)
#define log_debug(...) log_log(LOG_DEBUG, __FILE__, __LINE__, __VA_ARGS__)
#define log_info(...) log_log(LOG_INFO, __FILE__, __LINE__, __VA_ARGS__)
#define log_warn(...) log_log(LOG_WARN, __FILE__, __LINE__, __VA_ARGS__)
#define log_error(...) log_log(LOG_ERROR, __FILE__, __LINE__, __VA_ARGS__)
#define log_fatal(...) log_log(LOG_FATAL, __FILE__, __LINE__, __VA_ARGS__)const char* log_level_string(int level);
void log_set_lock(log_LockFn fn, void *udata);
void log_set_level(int level);
void log_set_quiet(bool enable);
int log_add_callback(log_LogFn fn, void *udata, int level);
int log_add_fp(FILE *fp, int level);void log_log(int level, const char *file, int line, const char *fmt, ...);#endif