tmp study note

本文介绍了Chromium项目的日志系统实现原理,包括如何通过不同的宏定义来设置和获取日志级别,以及如何使用这些宏来输出不同级别的日志信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值