GLog开源库使用

Glog地址:https://github.com/google/glog

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

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

(1)在glog-master文件夹内新建一个build文件夹,用于存放编译完成的文件。

(2)使用cmake-gui生成VS解决方案。如下图所示。

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

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

这时需要进行如下设置:

①是BUILD_SHARED_LIBS,这个选项我们要勾上,因为我们需要动态库。

②是CMAKE_INSTALL_PREFIX,这个路径是install后生成的头文件和库文件存放的路径,这里我们在源码同级目录下创建一个文件夹,命名为install。

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

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

2.利用VS对项目进行编译

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

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

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

3.错误类型

glog有四个错误级别,枚举如下:

cpp 复制代码
enum SeverityLevel
{
  google::INFO = 0,
  google::WARNING = 1,
  google::ERROR = 2,
  google::FATAL = 3,
};
4.输出日志
cpp 复制代码
LOG(INFO) << "info test";  //输出一个Info日志
LOG(WARNING) << "warning test";  //输出一个Warning日志
LOG(ERROR) << "error test";  //输出一个Error日志
LOG(FATAL) << "fatal test";  //输出一个Fatal日志,这是最严重的日志并且输出之后会中止程序
5.条件输出
cpp 复制代码
LOG_IF(INFO, num_cookies > 10) << "Got lots of cookies";  //当条件满足时输出日志

LOG_EVERY_N(INFO, 10) << "Got the " << google::COUNTER << "th cookie";  //google::COUNTER 记录该语句被执行次数,从1开始,在第一次运行输出日志之后,每隔 10 次再输出一次日志信息

LOG_IF_EVERY_N(INFO, (size > 1024), 10) << "Got the " << google::COUNTER << "th big cookie";  //上述两者的结合,不过要注意,是先每隔 10 次去判断条件是否满足,如果滞则输出日志;而不是当满足某条件的情况下,每隔 10 次输出一次日志信息

LOG_FIRST_N(INFO, 20) << "Got the " << google::COUNTER << "th cookie";  //当此语句执行的前 20 次都输出日志,然后不再输出
6.常用函数
cpp 复制代码
google::SetLogDestination(google::GLOG_INFO, "log/prefix_");  //设置特定严重级别的日志的输出目录和前缀。第一个参数为日志级别,第二个参数表示输出目录及日志文件名前缀

google::SetLogFilenameExtension("logExtension");  //在日志文件名中级别后添加一个扩展名。适用于所有严重级别

google::SetStderrLogging(google::GLOG_INFO);  //大于指定级别的日志都输出到标准输出
7.常用参数(Flags)
cpp 复制代码
FLAGS_logtostderr = true;  //设置日志消息是否转到标准输出而不是日志文件

FLAGS_alsologtostderr = true;  //设置日志消息除了日志文件之外是否去标准输出

FLAGS_colorlogtostderr = true;  //设置记录到标准输出的颜色消息(如果终端支持)

FLAGS_log_prefix = true;  //设置日志前缀是否应该添加到每行输出

FLAGS_logbufsecs = 0;  //设置可以缓冲日志的最大秒数,0指实时输出

FLAGS_max_log_size = 10;  //设置最大日志文件大小(以MB为单位)

FLAGS_stop_logging_if_full_disk = true;  //设置是否在磁盘已满时避免日志记录到磁盘
8.日志类型

日志有七个类型,其中最常用的是内置日志,枚举如下:

cpp 复制代码
LOG    //内置日志
VLOG    //自定义日志
DLOG    //DEBUG模式可输出的日志
DVLOG    //DEBUG模式可输出的自定义日志
SYSLOG    //系统日志,同时通过 syslog() 函数写入到 /var/log/message 文件
PLOG    //perror风格日志,设置errno状态并输出到日志中
RAW_LOG        //线程安全的日志,需要#include <glog/raw_logging.h>
9.示例
cpp 复制代码
#ifndef GLOG_NO_ABBREVIATED_SEVERITIES
#define GLOG_NO_ABBREVIATED_SEVERITIES // 如果不加这个宏定义代码就会报错
#endif

#include "widget.h"
#include <QApplication>
#include "glog/logging.h"

#pragma comment(lib, "glog.lib")
int main(int argc, char *argv[])
{
    FLAGS_logtostderr = true;
    FLAGS_colorlogtostderr = true;//是否启用不同颜色显示(如果终端支持)
    google::InitGoogleLogging(argv[0]);//使用glog之前必须先初始化库,仅需执行一次,括号内为程序名
    //google::SetLogDestination(google::GLOG_INFO, "E:\\logs\\INFO_");//INFO级别的日志都存放到logs目录下且前缀为INFO_
    LOG(INFO) << "info";
    LOG(WARNING) << "warning";
    LOG(ERROR) << "error";


    QApplication a(argc, argv);
    return a.exec();
}
相关推荐
Wyn_9 小时前
【QT】窗口/界面置于最前端显示,且激活该窗口
qt
XianxinMao14 小时前
开源AI崛起:新模型逼近商业巨头
人工智能·开源
软通动力14 小时前
软通动力携鸿湖万联与微展世签署战略合作协议,以开源鸿蒙赋能工业创新升级
开源·openharmony
千千道15 小时前
QT 中 UDP 的使用
开发语言·qt·udp
小众AI18 小时前
GFPGAN - 腾讯开源的图形修复算法修复算法
人工智能·算法·开源
奇树谦1 天前
C++|开源日志库log4cpp和glog
开发语言·c++·开源
说私域1 天前
深度内容运营与开源AI智能名片2+1链动模式S2B2C商城小程序在打造种草社区中的应用研究
人工智能·小程序·开源·内容运营
铁头乔1 天前
想从 IoTDB 中读取大量数据经过一定程度的分析再写入 MySQL 或 SQLServer,在这种需求下,哪一种 ETL 方案最适合
数据库·mysql·sqlserver·开源·时序数据库·iotdb
铁头乔1 天前
Java 中如何使用 SSL 连接 IoTDB
java·数据库·开源·ssl·时序数据库·iotdb
0xCC说逆向2 天前
Windows图形界面(GUI)-QT-C/C++ - QT 窗口属性
c语言·开发语言·c++·windows·qt·mfc