C实现日志等级控制
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdarg.h>
#include <time.h> #define SJXC_LOG_DEBUG(level, format, arg...) SJXC_log_msg_print(level, __FILE__, __func__, __LINE__, format, ##arg) #ifdef SJXC_DISABLE_DEBUG
#define SJXC_REAL_DEBUG_LEVEL 0
#else
#define SJXC_REAL_DEBUG_LEVEL SJXC_DEBUG_LEVEL
#endif #define SJXC_ERROR (1 << 0)
#define SJXC_WARN (1 << 1)
#define SJXC_INFO (1 << 2)
#define SJXC_DEBUG (1 << 3) int SJXC_DEBUG_LEVEL = ; struct SJXC_gdb {
int level;
const char *msg;
}; struct SJXC_gdb SJXC_gdb_table[] = {
{SJXC_ERROR, "Config the log level as error."},
{SJXC_WARN, "Config the log level as warn."},
{SJXC_INFO, "Config the log level as info."},
{SJXC_DEBUG, "Config the log level as DEBUG."}
}; void SJXC_print_debuf_usage(void)
{
struct SJXC_gdb *p_gdb;
fprintf(stderr,
" To calculate the debug level, logically 'or'\n"
" some of the following values together to get a bebug level:\n");
for (p_gdb = SJXC_gdb_table; p_gdb < SJXC_gdb_table + (sizeof(SJXC_gdb_table) / sizeof(struct SJXC_gdb)); p_gdb++) {
fprintf(stderr, "\t%d:\t%s\n", p_gdb->level, p_gdb->msg);
}
fprintf(stderr, "\n");
} void SJXC_log_msg_print(int level, const char *file, const char *func, const int line, char *fmt, ...)
{
char *status; switch (level) {
case SJXC_ERROR:
status = "ERROR";
break;
case SJXC_WARN:
status = "WRAN";
break;
case SJXC_INFO:
status = "INFO";
break;
case SJXC_DEBUG:
status = "DEBUG";
break;
default:
printf("Debug message level ERROR!\n");
} if (SJXC_REAL_DEBUG_LEVEL & level) {
char msg_buf[*];
char *ascii_time_buf;
time_t tnow = time(NULL);
va_list ap; ascii_time_buf = asctime(localtime(&tnow));
ascii_time_buf[strlen(ascii_time_buf) - ] = '\0'; va_start(ap, fmt);
sprintf(msg_buf, " ------> [ %s %s:%s:%d ] %s ", ascii_time_buf, file, func, line, status);
vsprintf(msg_buf + strlen(msg_buf), fmt, ap);
fprintf(stderr, "%s\n", msg_buf);
va_end(ap);
}
} #if 1
int main(void)
{
int i = ;
printf("%d\n", SJXC_REAL_DEBUG_LEVEL);
SJXC_print_debuf_usage();
while( i != ) {
SJXC_log_msg_print(SJXC_ERROR, __FILE__, __func__, __LINE__, "");
i++;
}
return ;
}
#endif
C实现日志等级控制的更多相关文章
- log4cplus使用(二)-自定义日志等级
log4cplus支持用户自定义日志等级,操作也比较简单,使用之前贴如下宏定义 #define LOG4CPLUS_MACRO_CREASH_LOG_LEVEL(pred) LOG4CPLUS_UNL ...
- 13.scrapy框架的日志等级和请求传参
今日概要 日志等级 请求传参 如何提高scrapy的爬取效率 今日详情 一.Scrapy的日志等级 - 在使用scrapy crawl spiderFileName运行程序时,在终端里打印输出的就是s ...
- python日志等级输出删选
有时候我们会删选一下输出的信息 当做日志进行文件保存 但是我们程序中有可能有自己不想存到日志文件中的输出信息 我们要做一些的删选 然后进行保存 代码如下: #!/usr/bin/python # - ...
- scrapy之日志等级
scrapy之日志等级 在settings.py中配置如下项: LOG_LEVEL = 'ERROR' # 当LOG_LEVEL设置为ERROR时,在进行日志打印时,只是打印ERROR级别的日志 这样 ...
- scrapy框架的日志等级和请求传参
日志等级 请求传参 如何提高scrapy的爬取效率 一.Scrapy的日志等级 - 在使用scrapy crawl spiderFileName运行程序时,在终端里打印输出的就是scrapy的日志信息 ...
- uniGUI日志的控制
uniGUI日志的控制 (2015-10-12 08:30:29) 转载▼ 标签: unigui 分类: uniGUI uniGUI本身提供了日志功能,利用uniServerModule.Server ...
- scrapy框架之日志等级和请求传参-cookie-代理
一.Scrapy的日志等级 - 在使用scrapy crawl spiderFileName运行程序时,在终端里打印输出的就是scrapy的日志信息. - 日志信息的种类: ERROR : 一般错误 ...
- Scrapy的日志等级和请求传参
日志等级 日志信息: 使用命令:scrapy crawl 爬虫文件 运行程序时,在终端输出的就是日志信息: 日志信息的种类: ERROR:一般错误: WARNING:警告: INFO:一般的信息: ...
- CEF之CefSettings设置日志等级
CefSettings结构体允许定义全局的CEF配置,经常用到的配置项如下: single_process 设置为true时,Browser和Renderer使用一个进程.此项也可以通过命令行参数“s ...
随机推荐
- swtich多个case使用同一操作
switch (expression) { case 'status01': case 'status02': case 'status03': alert('resultOne'); break; ...
- Day 7:TreeSet
补充上一日:HashCode方法默认返回的是内存地址,String类已经重写了对象的HashCode方法 方法细节:取出数组中的值或字符串的值按照规定计算返回一个值,如果两个字符串内容一致就会返回相同 ...
- [tensorflow] 线性回归模型实现
在这一篇博客中大概讲一下用tensorflow如何实现一个简单的线性回归模型,其中就可能涉及到一些tensorflow的基本概念和操作,然后因为我只是入门了点tensorflow,所以我只能对部分代码 ...
- 动态改变tableHeaderView的显示隐藏及高度
改变tableHeaderView的高度: UIView *headerView = _tableView.tableHeaderView; headerView.height = 10; 当设置高度 ...
- 吴裕雄--天生自然 JAVASCRIPT开发学习:函数调用
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- Git 报错:Updates were rejected because the tip of your current branch is behind
刚开始学习 git 命令,发现会出现很多的错误,所以就总结下出现的错误,以此来加深理解和掌握吧! 环境:在本地库操作了一系列的 add 和 commit 操作后,想把本地仓库推送到远端,但是发生以下错 ...
- POJ 1258:Agri-Net Prim最小生成树模板题
Agri-Net Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 45050 Accepted: 18479 Descri ...
- SpringBoot+SpringSecurity+jwt整合及初体验
原来一直使用shiro做安全框架,配置起来相当方便,正好有机会接触下SpringSecurity,学习下这个.顺道结合下jwt,把安全信息管理的问题扔给客户端, 准备 首先用的是SpringBoot, ...
- Shell程序实例集锦一
2007-12-13 07:51:40 标签:实例 程序 Shell 休闲 职场 Shell程序实例集锦一 前言:下面这些hell实例都是自己写的或者用过的一些Shell小程序.整理整理. ...
- 89.QuerySet API常用方法使用详解:count,first,last,aggregate,exists
1.count():计算数据的个数. 计算数据的个数可以使用count,在python中使用len()也可以计算数据的个数,但是相对来说效率没有使用count()效率高,因为在底层是使用select ...