前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >google glog 使用方法

google glog 使用方法

作者头像
bear_fish
发布2018-09-19 12:42:45
5.2K0
发布2018-09-19 12:42:45
举报

glog官方地址:https://code.google.com/p/google-glog/

glog作用:日志库

安装方法

./configure

make

make install

Hello world

foo_1.cpp

[cpp] view plain copy

  1. #include <glog/logging.h>
  2. int main(int argc,char* argv[]) {  
  3. // If glog is used to parse the command line 
  4. // google::ParseCommandLineFlags(&argc, &argv, true);
  5. // Initialize Google's logging library.
  6.     google::InitGoogleLogging(argv[0]);  
  7.     FLAGS_log_dir = "./log";  
  8.     LOG(INFO) << "hello world";  
  9. return 0;  
  10. }  

g++ -o foo_1 -lglog foo_1.cpp

运行后会在log目录下生成日志文件。

FLAGS_log_dir设置日志输出目录。google::ParseCommandLineFlags(&argc, &argv, true); 使用时,可解析命令行参数。如 foo_1 --log_dir=log

日志级别

INFO, WARNING, ERROR, FATAL、分别对应数字

0, 1, 2, 3

对应级别的日志打印在对应级别的日志文件中。

并且高级别的日志同时打印在本级别和低级别中。

例如 INFO中会有WARNING级别的输出。

日志文件

默认输出在“/tmp/”目录下,修改输出目录方法:

  • FLAGS_log_dir值修改
  • google::ParseCommandLineFlags(&argc, &argv, true); 使用时,命令行参数log_dir设置。

日志文件名称格式:<program name>.<hostname>.<user name>.log.<severity level>.<date>.<time>.<pid>

例如:hello_world.example.com.hamaji.log.INFO.20080709-222411.10474

本文开始处的例子中的 google::InitGoogleLogging(argv[0]); 参数便为设置程序名称。

初始化参数

FLAGS_log_dir       日志输出目录

FLAGS_v                 自定义VLOG(m)时,m值小于此处设置值的语句才有输出

FLAGS_max_log_size     每个日志文件最大大小(MB级别)

FLAGS_minloglevel       输出日志的最小级别,即高于等于该级别的日志都将输出。

更多参数可见 logging.h

并且各个参数均可以通过命令行参数的方式设置。

LOG_XX

满足一定条件下输出日志,例如:

LOG_IF(INFO, num_cookies > 10) << "Got lots of cookies";

该宏为:

#define LOG_IF(severity, condition) \

  !(condition) ? (void) 0 : google::LogMessageVoidify() & LOG(severity)

上一条语句则为num_cookies > 10为真时, LOG(INFO) << "Got lots of cookies";

logging.h 中还定义了很多其他的条件输出,可根据需要查找使用。

DLOG_XX

依赖于编译参数的LOG_XX,当使用-DNDEBUG编译时失效。该宏为:

#ifndef NDEBUG

#define DLOG(severity) LOG(severity)

还有很多其他的DLOG_XX, 参见头文件。

CHECK_XX

check检查失败时直接退出程序。类似assert()。

和assert的区别是不依赖于编译时的NDEBUG选项, 目的是尽快发现隐藏的问题。例如:

CHECK( fd != NULL ) << " fd is NULL, can not be used ! ";

#define CHECK(condition)  \

      LOG_IF(FATAL, GOOGLE_PREDICT_BRANCH_NOT_TAKEN(!(condition))) \

             << "Check failed: " #condition " "

还有很多CHECK_XX的宏,可参见头文件。

VLOG_XX

可以独立于默认的日志级别,用户自己定义自己的日志级别。

个人感觉不常用。

信号处理

个人感觉很有用,会输出导致程序结束的信号。SIGKILL 这个信号因为不可捕获所以不在这个信号处理之列。

只需使用google::InstallFailureSignalHandler(); 注册一下即可。

默认是打印到stderr中。

可以使用InstallFailureWriter()定义输出方式。该宏为:

GOOGLE_GLOG_DLL_DECL void InstallFailureWriter(

    void (*writer)(const char* data, int size));

}

RAW_XX  线程安全方式

<glog/raw_logging.h>中的各个RAW_XX为线程安全的使用方式。

官方特意说明“which does not allocate any memory or acquire any locks”。

结束

// Shutdown google's logging library.

GOOGLE_GLOG_DLL_DECL void ShutdownGoogleLogging();

结语

以上为 glog 一些简单总结,更细致的内容见相关文档及头文件。

有错误请指正,转发劳驾帖个地址。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017年01月12日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 安装方法
  • Hello world
  • 日志级别
  • 日志文件
  • 初始化参数
  • LOG_XX
  • DLOG_XX
  • CHECK_XX
  • VLOG_XX
  • 信号处理
  • RAW_XX  线程安全方式
  • 结束
  • 结语
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档