glog--介绍以及vs2010 vs2013 vs2015下编译

来源:互联网 发布:c语言编程简单的小游戏 编辑:程序博客网 时间:2024/04/29 19:35

在程序员的世界里,谷歌的东西都是自带光环的。

在C++的世界里,尽管有很多成熟的、知名的log库,但我还是要跟你介绍一个google出品的log库,名为glog.

官网:
https://code.google.com/archive/p/google-glog/

github:
https://github.com/google/glog

The glog library implements application-level logging. This library provides logging APIs based on C++-style streams and various helper macros.

主要功能:

1, 参数设置,以命令行参数的方式设置标志参数来控制日志记录行为;
2, 严重性分级,根据日志严重性分级记录日志;
3, 可有条件地记录日志信息;
4, 条件中止程序。丰富的条件判定宏,可预设程序终止条件;
5, 异常信号处理。程序异常情况,可自定义异常处理过程;
6, 支持debug功能。可只用于debug模式;
7, 自定义日志信息;
8, 线程安全日志记录方式;
9, 系统级日志记录;
10, google perror风格日志信息;
11, 精简日志字符串信息。

glog在vs2010下编译
打开google-glog.sln
编译
成功
在Debug文件夹下就有我们想要的libglog.dll libglog.lib等我们想要的文件

glog在vs2013下编译
打开google-glog.sln
编译
错误:’min’不是std的成员
这里写图片描述

解决方法:
添加头文件#include<algorithm>

重新编译
成功
在Debug文件夹下就有我们想要的libglog.dll libglog.lib等我们想要的文件

glog在vs2015下编译
打开google-glog.sln
编译
错误1:’min’不是std的成员
解决方法:
添加头文件#include<algorithm>

错误2:warning C4005: “va_copy”: 宏重定义
解决方法:
修改文件port.h,117行改为:

#undef va_copy#define va_copy(dst, src)  (dst) = (src)

错误3:
error C2084: 函数“int snprintf(char *const ,const size_t,const char *const ,…)”已有主体
c:\program files (x86)\windows kits\10\include\10.0.10150.0\ucrt\stdio.h(1932): note: 参见“snprintf”的前一个定义

解决方案:
修改snprintf的名字,比如改为snprintf_glog,记得所有的都要改

错误4:
d:\glog\glog-0.3.3\src\windows\glog\logging.h(1264): error C2280: “std::basic_ios

#define GLOG_NO_ABBREVIATED_SEVERITIES  #include <windows.h>  #include "glog/logging.h"using namespace google;int main(int argc, char* argv[]) {    google::InitGoogleLogging("test");    google::SetLogDestination(google::GLOG_INFO, "../Debug/logtestInfo");    google::SetLogDestination(google::GLOG_ERROR, "../Debug/logtestDebug");//不为ERROR建立日志文件      int num_cookies = 0;    google::SetStderrLogging(google::GLOG_INFO);    google::SetStderrLogging(google::GLOG_ERROR);    //google::LogToStderr();      for (int i = 0; i < 100; ++i) {        LOG(INFO) << "test google glog" << i << " cookies";     }    google::ShutdownGoogleLogging();}

可能发生的错误:
Error 2 error LNK2005: “public: __thiscall std::_Container_base12::_Container_base12(void)” (??0_Container_base12@std@@QAE@XZ) already defined in msvcprtd.lib(MSVCP120D.dll) D:\test\test_google_glog_vs2013\test_google_glog_vs2013\main.obj test_google_glog_vs2013

这个错误,是因为在编译库glog的时候,选择的代码生成方式和现在工程的代码生成方式不一样:
这里写图片描述

3 0