在Windows上编译、应用glog

    glog是google提供的一个开源的C++日志库。由于最新的glog源码工程中,已经移除了“.sln”文件,代之以“a CMake build system”,在Windows平台下应用最新的glog库,需要自行使用CMake来生成适用不同版本VS的“.sln”文件。这个过程相对来说,有点小繁琐,特以此文记录并分享给大家。

注:

glog下载链接:https://github.com/google/glog

cmake下载链接:https://cmake.org/download/

知乎上C++ log library评论贴:https://www.zhihu.com/question/37640953

glog文档:https://code.google.com/archive/p/google-glog/

                  https://godoc.org/github.com/golang/glog


一、下载

    直接登录github的链接,下载glog工程。然后再登录cmake官网,下载cmake工具,我选择的是绿色版——“.zip”文件。

    下载后将glog工程放在“glog”文件夹下,将cmake解压。


二、生成sln

1,在cmake文件夹下的bin文件夹中,找到“cmake-gui.exe”,双击打开

2,选择源文件夹和填写目标文件夹。


注:这一步可以参考https://stackoverflow.com/questions/41766969/installing-glog-on-windows

3,选择VS版本和编译器



点击“configure”,跳出上面的选择对话框,我本地装的是VS2015,它内置的是V140版本。


4,配置完成后,点击“generate”即可。


三、编译sln工程

    找到目标文件夹下的“glog.sln”文件,双击打开。直接生成即可。

    需要注意的是,默认“glog”生成的是静态链接的“glog.lib”。


四、测试

1,新建测试工程

    新建一个名为“glogtest”的win32工程,将“glog.lib”文件和原始glog工程下的“...\src\windows\glog”这个文件夹拷贝到新建的测试工程目录下。

2,加载lib文件

    有两种方式:一是在“工程属性 -> 链接器 -> 附加依赖项”中将“glog.lib”填进去;而是使用VC的预编译命令,如下:

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

3,添加“宏”和使用“namespace”

    在完成前面两步后,我进行了编译,老是报链接错误——“LINK2019”。大意就是不识别用到的glog.lib中的那几个导入函数。

    一般来说,这类链接错误就这么几个原因:

1)没找到*.lib文件(需检查路径设置是否正确);

2)工程入口不匹配,win32 console工程  .vs  Windows工程

3)导入函数全名不匹配,这个全名包括:调用约定、import/export关键字、C/C++接口声明关键字、函数名、参数。

    其中,前面几项受宏的影响,需要特别注意。


    因此,我先检查了glog.lib的路径,没发现问题。然后,对比glog原工程,发现它自带测试工程,在它的测试工程中发现如下宏:

    WIN32;_WINDOWS;GLOG_NO_ABBREVIATED_SEVERITIES;GOOGLE_GLOG_DLL_DECL=;

    将以上宏添加进“工程属性 -> C/C++ -> 预处理器”后,编译通过。

4,添加测试代码

    以下测试代码来自:http://www.cnblogs.com/hiloves/p/6009707.html


 
 
  1. #include "logging.h"
  2. using namespace google;
  3. #pragma comment(lib, "glog.lib")
  4. int main(int argc, char* argv[])
  5. {
  6. // Start google log system:
  7. FLAGS_log_dir = "d:\\Logs";
  8. google::InitGoogleLogging(argv[ 0]);
  9. google::SetLogDestination(google::GLOG_INFO, "d:\\Logs\\INFO_");
  10. google::SetStderrLogging(google::GLOG_INFO);
  11. google::SetLogFilenameExtension( "log_");
  12. FLAGS_colorlogtostderr = true; // Set log color
  13. FLAGS_logbufsecs = 0; // Set log output speed(s)
  14. FLAGS_max_log_size = 1024; // Set max log file size
  15. FLAGS_stop_logging_if_full_disk = true; // If disk is full
  16. char str[ 20] = "hello log!";
  17. LOG(INFO) << str;
  18. LOG(INFO) << "info test" << "hello log!"; //输出一个Info日志
  19. LOG(WARNING) << "warning test"; //输出一个Warning日志
  20. LOG(ERROR) << "error test"; //输出一个Error日志
  21. google::ShutdownGoogleLogging();
  22. return 0;
  23. }

使用简介:http://www.yeolar.com/note/2014/12/20/glog/

                  http://rpg.ifi.uzh.ch/docs/glog.html

gmock和gtest配合使用:

    https://games.greggman.com/game/using-a-mock-library-to-make-unit-testing-easier-in-c/

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值