Libevent源码分析——日志系统

Libevent日志系统

Libevent在默认情况下,会将日志信息输出到终端上,可以编写日志回调函数,在回调函数中把信息输出到一个文件上。Libevent允许提供日志回调函数接口,只需设置日志回调函数。当有日志时,Libevent库就会调用这个日志回调函数,回调函数的格式如下所示。

typedef void (*event_log_cb)(int severity, const char *msg);
void event_set_log_callback(event_log_cb cb);

第一个参数severity是级别类型,有下面这些:

#define EVENT_LOG_DEBUG 0
#define EVENT_LOG_MSG   1
#define EVENT_LOG_WARN  2
#define EVENT_LOG_ERR   3

/* Obsolete names: these are deprecated, but older programs might use them.
 * They violate the reserved-identifier namespace. */
#define _EVENT_LOG_DEBUG EVENT_LOG_DEBUG
#define _EVENT_LOG_MSG EVENT_LOG_MSG
#define _EVENT_LOG_WARN EVENT_LOG_WARN
#define _EVENT_LOG_ERR EVENT_LOG_ERR

Libevent是通过定义全局函数指针变量来指向用户定义的日志回调函数。

static event_log_cb log_fn = NULL;
void event_set_log_callback(event_log_cb cb)
{
   
log_fn = cb;
}

若用户不自己定义日志回调函数,libevent会调用默认的日志函数event_log函数,只是简单地根据参数判断日志记录的级别,然后把级别和内容输出。

static void event_log(int severity, const char *msg)
{
   

         if (log_fn)
                  log_fn(severity, msg);//调用用户的日志回调函数
         else {
   
                  const char *severity_str;
                  switch (severity) {
   
                  case _EVENT_LOG_DEBUG:
                          severity_str = "debug";
                          break;
                  case _EVENT_LOG_MSG:
                          severity_str = "msg";
                          break;
                  case _EVENT_LOG_WARN:
                          severity_str = "warn";
                          break;
                  case _EVENT_LOG_ERR:
                          severity_str = "err";
                          break;
         
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值