C++日志库 glog入门

2024-06-17 23:44
文章标签 c++ 日志 入门 glog

本文主要是介绍C++日志库 glog入门,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

glog(Google Logging Library)是由Google开源的一款C++日志库,用于方便地记录日志信息。它支持四个级别的日志(INFO、WARNING、ERROR、FATAL),并且可以将日志输出到文件和控制台,方便调试和问题追踪。以下是如何使用glog的详细说明。

安装glog

使用包管理器安装(例如在Ubuntu上)

sudo apt-get install libgoogle-glog-dev

从源码编译安装

git clone https://github.com/google/glog.git
cd glog
mkdir build
cd build
cmake ..
make
sudo make install

使用示例
以下是一个简单的示例,演示了如何在C++程序中使用glog:

示例代码

#include <glog/logging.h>int main(int argc, char* argv[]) {// 初始化gloggoogle::InitGoogleLogging(argv[0]);// 设置日志文件保存位置google::SetLogDestination(google::INFO, "./log_info_");google::SetLogDestination(google::WARNING, "./log_warning_");google::SetLogDestination(google::ERROR, "./log_error_");google::SetLogDestination(google::FATAL, "./log_fatal_");// 输出不同级别的日志信息LOG(INFO) << "This is an info message.";LOG(WARNING) << "This is a warning message.";LOG(ERROR) << "This is an error message.";// LOG(FATAL) << "This is a fatal message."; // 会导致程序退出// 条件日志int x = 10;LOG_IF(INFO, x > 5) << "x is greater than 5.";// 检查宏CHECK_EQ(x, 10) << "x should be 10.";// 关闭gloggoogle::ShutdownGoogleLogging();return 0;
}

使用CMake构建项目
如果你使用CMake构建项目,可以通过以下方式将glog集成到你的项目中:

CMakeLists.txt 示例

cmake_minimum_required(VERSION 3.10)
project(MyGlogProject)# 查找glog库
find_package(glog REQUIRED)# 添加可执行文件
add_executable(MyGlogProject main.cpp)# 链接glog库
target_link_libraries(MyGlogProject glog::glog)

glog的高级特性
设置日志选项

你可以通过修改glog的标志变量来定制日志行为。例如:

#include <glog/logging.h>int main(int argc, char* argv[]) {google::InitGoogleLogging(argv[0]);// 设置日志级别FLAGS_minloglevel = google::INFO;// 输出日志到stderrFLAGS_logtostderr = 1;LOG(INFO) << "This is an info message.";LOG(WARNING) << "This is a warning message.";LOG(ERROR) << "This is an error message.";google::ShutdownGoogleLogging();return 0;
}

用户自定义日志记录器
你可以设置自定义的日志记录器,以便自定义日志输出行为。例如:

#include <glog/logging.h>void MyLogHandler(const char* data, int size) {std::cout.write(data, size);std::cout << std::endl;
}int main(int argc, char* argv[]) {google::InitGoogleLogging(argv[0]);// 设置自定义日志记录器google::AddLogSink(new google::LogSinkAdapter(MyLogHandler));LOG(INFO) << "This is an info message.";LOG(WARNING) << "This is a warning message.";LOG(ERROR) << "This is an error message.";google::ShutdownGoogleLogging();return 0;
}

常用glog宏和函数

日志级别宏

  • LOG(INFO): 输出INFO级别的日志。
  • LOG(WARNING): 输出WARNING级别的日志。
  • LOG(ERROR): 输出ERROR级别的日志。
  • LOG(FATAL): 输出FATAL级别的日志,输出后程序会终止。

条件日志宏

  • LOG_IF(INFO, condition): 当condition为true时,输出INFO级别的日志。
  • LOG_IF(WARNING, condition): 当condition为true时,输出WARNING级别的日志。
  • LOG_IF(ERROR, condition): 当condition为true时,输出ERROR级别的日志。

检查宏

  • CHECK(condition): 如果condition为false,输出FATAL级别的日志,并终止程序。
  • CHECK_EQ(val1, val2): 如果val1 != val2,输出FATAL级别的日志,并终止程序。
  • CHECK_NE(val1, val2): 如果val1 == val2,输出FATAL级别的日志,并终止程序。
  • CHECK_LT(val1, val2): 如果val1 >= val2,输出FATAL级别的日志,并终止程序。
  • CHECK_LE(val1, val2): 如果val1 > val2,输出FATAL级别的日志,并终止程序。
  • CHECK_GT(val1, val2): 如果val1 <= val2,输出FATAL级别的日志,并终止程序。
  • CHECK_GE(val1, val2): 如果val1 < val2,输出FATAL级别的日志,并终止程序。

通过使用glog,你可以轻松地在C++项目中添加功能强大的日志记录,帮助你更好地进行调试和问题追踪。

这篇关于C++日志库 glog入门的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1070727

相关文章

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

C#如何调用C++库

《C#如何调用C++库》:本文主要介绍C#如何调用C++库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录方法一:使用P/Invoke1. 导出C++函数2. 定义P/Invoke签名3. 调用C++函数方法二:使用C++/CLI作为桥接1. 创建C++/CL

C++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

Java程序进程起来了但是不打印日志的原因分析

《Java程序进程起来了但是不打印日志的原因分析》:本文主要介绍Java程序进程起来了但是不打印日志的原因分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java程序进程起来了但是不打印日志的原因1、日志配置问题2、日志文件权限问题3、日志文件路径问题4、程序

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

python logging模块详解及其日志定时清理方式

《pythonlogging模块详解及其日志定时清理方式》:本文主要介绍pythonlogging模块详解及其日志定时清理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录python logging模块及日志定时清理1.创建logger对象2.logging.basicCo

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

Qt spdlog日志模块的使用详解

《Qtspdlog日志模块的使用详解》在Qt应用程序开发中,良好的日志系统至关重要,本文将介绍如何使用spdlog1.5.0创建满足以下要求的日志系统,感兴趣的朋友一起看看吧... 目录版本摘要例子logmanager.cpp文件main.cpp文件版本spdlog版本:1.5.0采用1.5.0版本主要