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.1 define
- 5.2 include
- 5.3 InitGoogleLogging
- 5.4 ShutdownGoogleLogging
一、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;//是否将日志输出到文件和stderrgoogle::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;//是否将日志输出到文件和stderrFLAGS_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的安装与使用超详解相关推荐
- win10下MYSQL的下载、安装以及配置超详解教程
下载MYSQL 官网下载MYSQL5.7.21版本,链接地址https://www.mysql.com/downloads/.下载流程图如下: 进入官网点击Community,下载社区版. 找到 ...
- C++第三方日志库Pantheios
C++第三方日志库Pantheios 简介 在项目实践中发现一个好的日志记录非常重要,你需要借助Logging才能跟踪软件中的错误.所以这里研究下第三方C++库Pantheios的使用. Panthe ...
- mac python3.8上怎么安装pygame 第三方库_Python3.8安装Pygame Python3.8安装Pygame教程步骤详解...
想了解Python3.8安装Pygame教程步骤详解的相关内容吗,孤傲小二~阿沐在本文为您仔细讲解Python3.8安装Pygame的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:Pyth ...
- PyKivy入门教程:Kivy Python库的介绍、安装及使用方法详解
PyKivy入门教程:Kivy Python库的介绍.安装及使用方法详解 Kivy是一个跨平台的Python GUI工具包,可以用于开发能够在多种设备和操作系统上运行的应用程序.Kivy支持触摸输入. ...
- CentOS7下的软件安装方法及策略详解
CentOS7下的软件安装方法及策略详解 互联网 01-24 15:15:09 作者:佚名 我要评论 今天小编为大家带来的是CentOS7下的软件安装方法及策略详解:希望对大家安装Cent ...
- CentOS 8.1安装MySQL 8.0详解
CentOS 8.1安装MySQL 8.0详解 引言 一.YUM在线安装 0.删除已安装的MySQL 1.添加MySQL Yum Repository 2.选择MySQL版本 3.安装MySQL 4. ...
- mysql拷贝文件安装_Mysql5.7.18的安装与主从复制图文详解
CentOS6.7安装mysql5.7.18 1. 解压到/usr/local目录 # tar -zxvf mysql-5.7.18-linux-glibc2.5-i686.tar.gz -C /u ...
- WSO2安装使用的全过程详解
WSO2安装使用的全过程详解 1. Wso2 Install 1.0 Port 1.1 Docker Install 1.2 Uninstall 2. Git Install 2.0 Port 2.1 ...
- 秦疆 西部开源_Win10下安装Hadoop3.1.2详解
https://my.oschina.net/zengfr 文章内容已测试验证可用 即使再小的帆也能远航 西部开源-秦疆老师:Hadoop系列博客 , 秦老师交流Q群号: 664386224 , 未授 ...
最新文章
- 学好C++十大良好的习惯
- python sys.argv 默认值
- .net Windows服务程序和安装程序制作图解
- 4 Redis的发布订阅
- Beetlex.Redis之Stream功能详解
- 什么时候使用Apache Camel?
- java获取word书签表格数据_Python读取word文档里面的表格数据
- 手持巡检仪_专业的三防产品设计-电力巡检仪设计
- 2021-08-08三大范式与JDBC
- linux免采集卡直播ps4,ps4免采集卡直播方法
- eclipse安装教程 以及汉化包安装
- 影像篡改与识别(三):人工智能时代
- python词性标注_自然语言处理基础技术之词性标注
- 在职研一英语课件难句整理
- 联通数据能力开放平台介绍
- 读书笔记之JVM垃圾回收
- Android按返回键(后退键)Back键事件捕获的两种方法
- 做什么网站赚钱?关于网站赚钱项目的剖析以及方向
- 【2016读书】3月读书笔记
- 【计算机毕业设计】79.勤工助学管理系统源码