当前位置: 首页 > news >正文

glog使用详解和基本使用示例

glog 是 Google 开源的一个 C++ 日志库,全称 Google Logging Library,适用于大型 C++ 项目,支持等级日志输出(INFO/WARNING/ERROR/FATAL)、日志文件输出、条件日志、调试检查、堆栈追踪等功能。


一、glog 特性简述

  • 多级别日志输出:LOG(INFO), LOG(WARNING), LOG(ERROR), LOG(FATAL)
  • 检查宏:CHECK, CHECK_EQ, CHECK_NE, 等
  • 条件日志:LOG_IF, LOG_EVERY_N, LOG_FIRST_N
  • 可输出到标准输出、日志文件或自定义路径
  • 支持线程安全、堆栈跟踪(FATAL 时)

二、不同环境安装方法

Ubuntu / Debian

sudo apt install libgoogle-glog-dev

Windows + vcpkg

vcpkg install glog

CMake 配置(跨平台)

find_package(glog REQUIRED)
target_link_libraries(your_target PRIVATE glog::glog)

三、基础用法示例

初始化和基本日志

#include <glog/logging.h>int main(int argc, char* argv[]) {google::InitGoogleLogging(argv[0]);// 日志输出等级LOG(INFO)    << "这是一个信息日志";LOG(WARNING) << "这是一个警告日志";LOG(ERROR)   << "这是一个错误日志";// 致命错误,程序将中止// LOG(FATAL) << "致命错误";return 0;
}

默认日志输出到:

  • 屏幕(stderr
  • 文件:/tmp/<program>.<severity>.<pid>.log

四、日志等级与控制

设置最小输出等级

FLAGS_minloglevel = 1;  // 0: INFO, 1: WARNING, 2: ERROR, 3: FATAL

也可通过命令行参数控制:

./your_program --minloglevel=2

五、检查宏 CHECK 系列(崩溃检查)

int a = 5, b = 3;
CHECK(a > b) << "a 应该大于 b,否则程序终止";
CHECK_EQ(a, 5);   // 等于
CHECK_NE(a, b);   // 不等于
CHECK_LT(b, a);   // 小于
CHECK_GE(a, 5);   // 大于等于
  • 检查失败会立即终止程序
  • CHECK_* 会打印出当前行数、错误堆栈

六、条件日志(调试/频率控制)

只在条件为真时打印

int x = 10;
LOG_IF(INFO, x > 5) << "x 大于 5";

每 N 次打印一次

for (int i = 0; i < 100; ++i) {LOG_EVERY_N(INFO, 10) << "第 " << i << " 次";
}

前 N 次打印

for (int i = 0; i < 100; ++i) {LOG_FIRST_N(INFO, 3) << "仅输出前 3 次,第 " << i << " 次";
}

七、自定义日志目录/文件

FLAGS_log_dir = "/your/log/dir";

或者在命令行指定:

./your_program --log_dir=./log

日志文件默认命名为:

<program>.<level>.<hostname>.<user>.log.<timestamp>.<pid>

八、线程安全和性能建议

  • glog 日志是线程安全的
  • 在多线程程序中可放心使用
  • 高性能场景建议控制 LOG_EVERY_N 或禁用 INFO 日志

九、终止时打印堆栈(仅 FATAL

LOG(FATAL)CHECK 失败时:

  • 会自动打印调用堆栈
  • 在 Linux 下需支持 backtrace(),可以通过 glog 的堆栈解析辅助程序查看

十、完整示例代码

#include <iostream>
#include <glog/logging.h>void test_log() {int a = 10, b = 5;LOG(INFO) << "程序启动...";LOG_IF(WARNING, a > b) << "a 大于 b";for (int i = 0; i < 30; ++i) {LOG_EVERY_N(INFO, 10) << "循环中,第 " << i << " 次";}CHECK_EQ(a, 10) << "a 不为 10,出错!";
}int main(int argc, char* argv[]) {// 初始化 gloggoogle::InitGoogleLogging(argv[0]);// 设置日志路径FLAGS_log_dir = "./log";         // 日志文件保存目录FLAGS_alsologtostderr = 1;       // 同时输出到终端test_log();// 清理google::ShutdownGoogleLogging();return 0;
}

十一、关闭日志或静默模式

在生产环境中关闭某些日志:

FLAGS_minloglevel = 2;      // 仅 ERROR 与 FATAL
FLAGS_logtostderr = 0;      // 不输出到终端
FLAGS_alsologtostderr = 0;  // 不附加输出

十二、典型 glog 与 gflags 组合(推荐)

glog 常与 gflags 一起使用,用于命令行参数解析:

#include <gflags/gflags.h>
#include <glog/logging.h>DEFINE_string(config, "config.json", "配置文件路径");int main(int argc, char* argv[]) {google::InitGoogleLogging(argv[0]);gflags::ParseCommandLineFlags(&argc, &argv, true);LOG(INFO) << "配置文件:" << FLAGS_config;return 0;
}

总结:何时用 glog?

场景推荐使用
开发调试日志LOG(INFO) 等级
检查条件崩溃CHECK, CHECK_EQ
定期日志LOG_EVERY_N, LOG_IF
发布版日志保存设置 --log_dir 输出日志
日志静默控制使用 FLAGS_minloglevel
http://www.lqws.cn/news/562177.html

相关文章:

  • 数据结构:顺序表
  • Lua现学现卖
  • Java代码阅读题
  • 06-three.js 创建自己的缓冲几何体
  • 某音Web端消息体ProtoBuf结构解析
  • 【网络安全】网络安全中的离散数学
  • 机器学习算法-K近邻算法-KNN
  • BUUCTF [ACTF新生赛2020]music 1
  • SpringMVC系列(五)(响应实验以及Restful架构风格(上))
  • 【学习】《算法图解》第七章学习笔记:树
  • [论文阅读] 软件工程 | 微前端在电商领域的实践:一项案例研究的深度解析
  • Linux软件的安装目录
  • 【面板数据】省级电商指数与地级市电子商务交易额数据集(1990-2022年)
  • OpenLayers 下载地图切片
  • Docker安装MinIO
  • 概述-4-通用语法及分类
  • 【go】初学者入门环境配置,GOPATH,GOROOT,GOCACHE,以及GoLand使用配置注意
  • 案例开发 - 日程管理系统 - 第一期
  • Redis 实现分布式锁
  • 【C++进阶】--- 继承
  • 鸿蒙 Grid 与 GridItem 深度解析:二维网格布局解决方案
  • 复杂驱动开发-TLE9471的休眠流程与定时唤醒
  • Python训练营-Day44-预训练模型
  • Java中的异常及异常处理
  • JDK17的GC调优
  • SpringCloud Stream 使用
  • Youtube双塔模型
  • 第27篇:SELinux安全增强机制深度解析与OpenEuler实践指南
  • eTools 开源发布
  • 如何在 Ubuntu 上通过终端或在 VirtualBox 中安装 GCC