tmp study note

chromium log macro


logging.cc

里面有min_log_level,minimal log level,可以设置或者获取这个level,SetMinLogLevel,GetMinLogLevel。(c++的## 处理器,会忽略空格)
在实现中SetMinLogLevel,最小的level,取std::min(LOG_FATAL, level);
const LogSeverity LOG_INFO = 0;
const LogSeverity LOG_WARNING = 1;
const LogSeverity LOG_ERROR = 2;
const LogSeverity LOG_FATAL = 3;
const LogSeverity LOG_NUM_SEVERITIES = 4;


#define LAZY_STREAM(stream, condition)                                  \
  !(condition) ? (void) 0 : ::logging::LogMessageVoidify() & (stream)
一个辅助宏,如果条件不存在,就不初始化流。


打印log的宏如下,这个log最终返回一个stream流
#define LOG(severity) LAZY_STREAM(LOG_STREAM(severity), LOG_IS_ON(severity))
而#define LOG_STREAM(severity) COMPACT_GOOGLE_LOG_ ## severity.stream()
COMPACT_GOOGLE_LOG_severity.stream 是定义好的stream(里面实现有些饶)


LOG(INFO) << "Found " << num_cookies的最终结果就是:
!(((::logging::LOG_INFO) >= 1))) ? (void) 0 : ::logging::LogMessageVoidify() & (logging::LogMessage("a.c", 99, logging::LOG_INFO).stream()) << "Found " << num_cookies;
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值