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

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联