C++第三方日志库Glog的安装与使用超详解

一、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库的基本语法进行详细介绍,欢迎关注~

整理不易,如果对你有所帮助,记得点个赞哟~


参考:

  1. https://blog.csdn.net/w_b_h/article/details/107070652
  2. https://blog.csdn.net/qq_27278957/article/details/84648912
  3. https://blog.csdn.net/fx_odyssey/article/details/102815949
  4. https://blog.csdn.net/weixin_33929309/article/details/85541046
  5. https://www.cnblogs.com/tianyajuanke/archive/2013/02/22/2921850.html
  6. https://my.oschina.net/u/4320185/blog/3755592
  • 25
    点赞
  • 114
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论
在Linux上使用glog静态的步骤如下所示: 1. 首先,将glog的静态文件libglog.a和头文件src/glog复制到您的工程目录中。这些文件可以从引用中提供的资源中获取。 2. 接下来,创建一个名为main.cpp的文件,并将以下代码添加到该文件中: ``` /******************************************************** main.cpp ********************************************************/ #include <stdio.h> #include "glog/logging.h" int main() { // 初始化参数 FLAGS_logtostderr = false; // TRUE:标准输出,FALSE:文件输出 FLAGS_alsologtostderr = true; // 除了日志文件之外是否需要标准输出 FLAGS_colorlogtostderr = false; // 标准输出带颜色 FLAGS_logbufsecs = 0; // 设置可以缓冲日志的最大秒数,0指实时输出 FLAGS_max_log_size = 10; // 日志文件大小(单位:MB) FLAGS_stop_logging_if_full_disk = true; // 磁盘满时是否记录到磁盘 google::InitGoogleLogging("mqttserver"); google::SetLogDestination(google::GLOG_INFO, "./test"); LOG(INFO) << "this is log"; LOG(WARNING) << "this is warning"; LOG(ERROR) << "this is error"; google::ShutdownGoogleLogging(); } ``` 3. 编译和链接您的代码。您可以使用以下命令编译您的代码: ``` g++ main.cpp -o main -lglog ``` 这将生成一个名为main的可执行文件。 4. 运行您的程序。您可以使用以下命令运行您的程序: ``` ./main ``` 这将执行您的代码,并在"./test"目录下生成日志文件。 请注意,如果在编译过程中遇到任何错误,请根据引用中提供的信息检查头文件的路径是否正确,并确保已正确安装gflags和glog,如引用所述。 希望这可以帮助您在Linux上使用glog静态。如果您还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wendy_ya

您的鼓励将是我创作的最大动力~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值