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 ...
随机推荐
- vmware桥接模式-无法内网通-克隆机要删除的文件-ssl
网卡太多自动模式有时候无法正常通信需要绑定外部网卡 rm /etc/udev/rules.d/-persistent-ipoib.rules vmware报错 Microsoft Runtime DL ...
- 关于torch.nn.Conv2d的笔记
先看一下CLASS有哪些参数: torch.nn.Conv2d( in_channels, out_channels, kernel_size, stride=1, padding=0, dilati ...
- argv从控制台输入多个参数
arg多个参数: #!/usr/bin/env python3 import sys #控制台要输入的两个参数格式为:python script_name.py 参数1 参数2 input_file= ...
- nested exception is java.lang.IllegalArgumentException: warning no match for this type name: res [Xlint:invalidAbsoluteTypeName]
注:内有单词(sping)写错,请忽略,不影响程序运行 运行时报错: Exception in thread "main" org.springframework.beans.fa ...
- PyMySQL学习笔记
一些常用函数及解释 db = pymysql.connect('host','user','password','database') # 连接数据库 cursor = db.cursor() # 创 ...
- Tomcat导入工程
Windows->Preference->Server->Runtime environment->Add浏览路径(选择Workbench default JRE)
- 51nod A 魔法部落(逆元费马小定理)
A 魔法部落 小Biu所在的部落是一个魔法部落,部落中一共有n+1个人,小Biu是魔法部落中最菜的,所以他的魔力值为1,魔法部落中n个人的魔法值都不相同,第一个人的魔法值是小Biu的3倍,第二个人的魔 ...
- python3编码问题个人理解
#coding=utf-8 a = "你" # 这个字符串是Unicode和 a = u“你”等价b = b'\\u4f60' #这个表示b是字节串(如果需要显示b的值则 prin ...
- 同行评审|keywords
审稿流程: 初审 直接被拒,editor开组会讨论的结果 论文水平低 不符合刊物宗旨和要求 同行评审: 单盲评审 双盲评审:限制审稿人倾向 公开评审PNAS Analyse search result ...
- 题解【[HAOI2006]受欢迎的牛】
切水题,写题解~ tarjan缩一波点,然后 只有一个出度为0的点:他的size就是答案 有多个初度为0的点:无解,0个 因为是强联通分量,所以肯定有出度为0的点,否则--就是你tarjan写挂了~ ...