C++第三方日志库Glog的安装与使用介绍

目录
  • 一、glog介绍
  • 二、glog下载
  • 三、环境介绍
  • 三、glog的编译详解
    • 3.1利用CMake进行编译,生成VS解决方案
    • 3.2利用VS对项目进行编译
  • 四、glog的基本使用
    • 4.1创建VS项目
    • 4.2将glog相关文件包含在项目中
    • 4.3编写代码进行测试
    • 4.4测试代码2
  • 五、代码详解
    • 5.1define
    • 5.2include
  • 参考:

一、glog介绍

Google Logging(glog)是一个实现应用程序级日志记录的C++98库。该库提供了基于C++风格流和各种辅助宏的日志API。

二、glog下载

Glog的地址已经从https://code.google.com/p/google-glog/ 变为了https://github.com/google/glog,请从该链接地址下载最新版。

官方文档:http://google-glog.googlecode.com/svn/trunk/doc/glog.html。

三、环境介绍

本文配置所采用的环境为Visual Studio2017。

三、glog的编译详解

3.1 利用CMake进行编译,生成VS解决方案

首先需要下载并安装CMake,下载方法参考文章:Windows下CMake的下载与安装详解。

然后需要从github上下载glog的源码。我们这里将源码下载到文件夹E:\3PartyLibrary下。
然后在glog-master文件夹内新建一个build文件夹,用于存放编译完成的文件。
【注意】:如果建在该文件夹外部,会引发错误!!!

然后使用cmake-gui生成VS解决方案。如下图所示。

这里选择你使用的编译器(我这里使用的是Visual Studio2017),然后在下方输入x64:

点击Finish完成。稍等几分钟CMake进行配置,配置完毕后如下图所示:

这时需要进行如下设置:

①是BUILD_SHARED_LIBS,这个选项我们要勾上,因为我们需要动态库。
②是CMAKE_INSTALL_PREFIX,这个路径是install后生成的头文件和库文件存放的路径,这里我们在源码同级目录下创建一个文件夹,命名为install。

③和④分别是WITH_GFLAGS和WITH_UNWIND,这两个我也不是很清楚是做什么的,但是如果把这两个勾上的话,在cmake的过程中就会报warning,因此都不勾。

之后分别点击Configure和Generate,生成完成后没有红色选项。

3.2 利用VS对项目进行编译

上述步骤生成完毕后,会在build目录下会生成sln解决方案,使用Visual Studio打开glog.sln解决方案,打开后目录如下:

选择Release模式,分别对ALL_BUILD和INSTALL两个项目进行生成,如下图所示。(如果项目在debug模式下开发,就在debug模式下生成glog的DLL文件;如果项目在release模式下开发,就在release模式下生成glog的DLL文件;我这里选择的是Release模式)

生成过程应该不会有错误。

生成成功后就在install目录下生成头文件和库文件。如下图所示。

ok!以上便是glog编译的全部内容了,接下来的小节介绍一下glog的基本使用。

四、glog的基本使用

4.1 创建VS项目

新建一个Visual Studio项目,Release生成。

这里,为了代码目录结构清晰,将上面生成的头文件放在了include文件夹中,将上面生成的.lib文件放在了lib文件夹中,将上面生成的.dll文件放在工程所在文件夹中,如下图所示。

4.2 将glog相关文件包含在项目中

在使用vs新建项目后,需要将我们上面生成的头文件包含在项目的Include Directories中,将上面生成的库文件包含在项目的Library Directories中。如下图所示。

【注意】:一定要选择x64和Release!!!

4.3 编写代码进行测试

最简单的测试代码如下:

#ifndef GLOG_NO_ABBREVIATED_SEVERITIES
#define GLOG_NO_ABBREVIATED_SEVERITIES // 如果不加这个宏定义代码就会报错
#endif
#include <glog/logging.h>

#pragma comment(lib, "glog.lib")

int main(int argc, char* argv[])
{
	FLAGS_alsologtostderr = true;//是否将日志输出到文件和stderr
	google::InitGoogleLogging("test");//使用glog之前必须先初始化库,仅需执行一次,括号内为程序名
	LOG(INFO) << "Hello,GLOG!";
	google::ShutdownGoogleLogging();//当要结束glog时必须关闭库,否则会内存溢出

	return 0;
}

输出为:

I20220220 14:27:55.136509 5080 test.cpp:9] Hello,GLOG!

【注意】:GLog在整个项目周期中只允许生成一个日志文件,也就是说,glog从初始化到注销整个过程,不允许再次调用glog的初始化或者注销,另一种意思可以理解为只允许有一个实例化对象。

4.4 测试代码2

测试代码如下:

#ifndef GLOG_NO_ABBREVIATED_SEVERITIES
#define GLOG_NO_ABBREVIATED_SEVERITIES // 如果不加这个宏定义代码就会报错
#endif
#include <glog\logging.h>

#pragma comment(lib, "glog.lib")
int main()
{
	google::InitGoogleLogging("test");//使用glog之前必须先初始化库,仅需执行一次,括号内为程序名
	FLAGS_alsologtostderr = true;//是否将日志输出到文件和stderr
	FLAGS_colorlogtostderr = true;//是否启用不同颜色显示
	google::SetLogDestination(google::GLOG_INFO, "E:\\logs\\INFO_");//INFO级别的日志都存放到logs目录下且前缀为INFO_
	google::SetLogDestination(google::GLOG_WARNING, "E:\\logs\\WARNING_");//WARNING级别的日志都存放到logs目录下且前缀为WARNING_
	google::SetLogDestination(google::GLOG_ERROR, "E:\\logs\\ERROR_");	//ERROR级别的日志都存放到logs目录下且前缀为ERROR_
	google::SetLogDestination(google::GLOG_FATAL, "E:\\logs\\FATAL_");	//FATAL级别的日志都存放到logs目录下且前缀为FATAL_
	LOG(INFO) << "info";
	LOG(WARNING) << "warning";
	LOG(ERROR) << "error";
	/*LOG(FATAL) << "fatal";*/
	google::ShutdownGoogleLogging();//当要结束glog时必须关闭库,否则会内存溢出
	return 0;
}

代码执行后,会在E:\logs文件夹下生成四个log文件,这里我没有将FATAL也打印出来是因为当glog检测到"LOG(FATAL)<<"代码时就会直接结束程序,不继续执行后面的代码。

五、代码详解

5.1 define

除了上述在前三行加入代码外,也可以选择添加预处理项。项目属性 ——> c/c++ ——> 预处理器。 添加GLOG_NO_ABBREVIATED_SEVERITIES。

5.2 include

在需要使用glog打印日志的cpp文件中包含头文件,及加载glog库文件。注意:每个使用glog的cpp文件都要添加,代码如下:

#include "glog/logging.h"
#pragma comment(lib,"libglog.lib")

5.3 InitGoogleLogging

用glog之前必须先初始化库,要生成日志文件只需在开始log之前调用一次:

google::InitGoogleLogging(argv[0]);  //括号内是程序名

5.4 ShutdownGoogleLogging

当要结束glog时必须关闭库,否则会内存溢出:

google::ShutdownGoogleLogging();

下一篇文章(C++第三方日志库Glog基本语法介绍)会对glog库的基本语法进行详细介绍,欢迎关注~

参考:

https://blog.csdn.net/w_b_h/article/details/107070652
https://blog.csdn.net/qq_27278957/article/details/84648912
https://blog.csdn.net/fx_odyssey/article/details/102815949
https://blog.csdn.net/weixin_33929309/article/details/85541046
https://www.cnblogs.com/tianyajuanke/archive/2013/02/22/2921850.html
https://my.oschina.net/u/4320185/blog/3755592

到此这篇关于C++第三方日志库Glog的安装与使用介绍的文章就介绍到这了,更多相关C++第三方日志库Glog内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C++第三方日志库log4cplus的安装与使用配置教程

    目录 一.log4cplus介绍 二.log4cplus下载 三.log4cplus配置 3.1打开解决方案 3.2进行相应设置 3.3目标程序的配置 四.测试Demo 一.log4cplus介绍 log4cplus是C++编写的开源的日志系统,前身是java编写的log4j系统,受Apache Software License保护,作者是Tad E. Smith. log4cplus具有线程安全.灵活.以及多粒度控制的特点,通过将日志划分优先级使其可以面向程序调试.运行.测试.和维护等全生命周

  • C++第三方日志库Glog基本语法详解

    目录 1.错误类型 2.输出日志 3.条件输出 4.常用函数 5.常用参数(Flags) 6.日志类型 上文(C++第三方日志库Glog的安装与使用超详解(精选))介绍了glog的安装.配置与基本使用案例,本文将详细介绍一下glog的基本语法,结合上文一起食用效果更佳哦~ 1.错误类型 glog有四个错误级别,枚举如下: enum SeverityLevel { google::INFO = 0, google::WARNING = 1, google::ERROR = 2, google::F

  • C++第三方日志库Glog的安装与使用介绍

    目录 一.glog介绍 二.glog下载 三.环境介绍 三.glog的编译详解 3.1利用CMake进行编译,生成VS解决方案 3.2利用VS对项目进行编译 四.glog的基本使用 4.1创建VS项目 4.2将glog相关文件包含在项目中 4.3编写代码进行测试 4.4测试代码2 五.代码详解 5.1define 5.2include 参考: 一.glog介绍 Google Logging(glog)是一个实现应用程序级日志记录的C++98库.该库提供了基于C++风格流和各种辅助宏的日志API.

  • .NET 6开发TodoList应用引入第三方日志库

    目录 1.需求 2.目标 3.原理和思路 4.实现 4.1日志配置实现 4.2主程序配置 4.3注入使用 5.验证 1.需求 在我们项目开发的过程中,使用.NET 6自带的日志系统有时是不能满足实际需求的,比如有的时候我们需要将日志输出到第三方平台上,最典型的应用就是在各种云平台上,为了集中管理日志和查询日志,通常会选择对应平台的日志SDK进行集成.使用Serilog提供的多种Sink,可以实现将日志写入不同云平台或者是非云平台的日志存储中去,这是我们这篇文章讲要研究的内容. 2.目标 我们将为

  • go日志库logrus的安装及快速使用

    目录 安装简介 快速使用 支持的日志级别 日期 打印调用位置 添加字段 给字段值加引号 设置钩子 设置channel 输出日志 安装简介 Logrus是Go的结构化日志记录器,与标准的日志记录器库完全API兼容. go get安装的logrus库 go get github.com/sirupsen/logrus 快速使用 package main import ( log "github.com/sirupsen/logrus" ) func main() { log.SetLeve

  • python第三方异步日志库loguru简介

    目录 一.引言 二.安装loguru 三.特性 3.1 开箱即用 3.2 无需初始化,导入函数即可使用 3.3 更容易的文件日志记录与转存/保留/压缩方式 3.4 更优雅的字符串格式化输出 3.5 可以在线程或主线程中捕获异常 3.6 可以支持自定义颜色 3.7 支持异步,且线程和多进程安全 3.8 支持异常完整性描述 3.9 更好的日期时间处理 3.10 支持邮件通知 四.总结 一.引言 在编写调试Python代码过程中,我们经常需要记录日志,通常我们会采用python自带的内置标准库logg

  • 2022最新Python日志库logging总结

    目录 1.日志级别 2.logging 流程 3.日志输出格式 4.基本使用 5.自定义 Logger 6.Logger 配置 7.实战中的问题 在部署项目时,不可能直接将所有的信息都输出到控制台中,我们可以将这些信息记录到日志文件中,这样不仅方便我们查看程序运行时的情况,也可以在项目出现故障时根据运行时产生的日志快速定位问题出现的位置. 1.日志级别 Python 标准库 logging 用作记录日志,默认分为六种日志级别(括号为级别对应的数值),NOTSET(0).DEBUG(10).INF

  • Python 安装第三方库 pip install 安装慢安装不上的解决办法

    今天来说一下,有些刚刚接触python的朋友,在使用pip install安装python 第三方库的过程中 会出现网速很慢,或者是安装下载到中途,停止,卡主,或者是下载报错等问题.如下图: 还有一些,等等之类的问题,比如我这图中,下载速度只有4.7kb/s 慢的比龟速还慢. 怎么样解决这种问题呢? 就是更换python源 临时的使用方法是,在安装pip install -i + 源地址+ 安装库名,这样可以临时解决安装问题 例如:pip install -ihttps://pypi.tuna.

  • python3第三方爬虫库BeautifulSoup4安装教程

    Python3安装第三方爬虫库BeautifulSoup4,供大家参考,具体内容如下 在做Python3爬虫练习时,从网上找到了一段代码如下: #使用第三方库BeautifulSoup,用于从html或xml中提取数据 from bs4 import BeautifulSoup 自己实践后,发现出现了错误,如下所示:    以上错误提示是说没有发现名为"bs4"的模块.即"bs4"模块未安装.    进入Python安装目录,以作者IDE为例,    控制台提示第三

  • python实现简单日志记录库glog的使用

    这篇文章主要介绍了python实现简单日志记录库glog的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 一. glog的简介 glog所记录的日志信息总是记录到标准的stderr中,即控制台终端. 每一行日志记录总是会添加一个谷歌风格的前缀,即google-style log prefix, 它的形式如下: E0924 22:19:15.123456 19552 filename.py:87] some message 上面红色部分加粗的

随机推荐