C++日志类libglog使用

来源:互联网 发布:淘宝usa商城 假货 编辑:程序博客网 时间:2024/06/05 14:57
glog简介 
Google glog是一个基于程序级记录日志信息的c++库,编程使用方式与c++的stream操作类似,例:
       LOG(INFO) << "Found " << num_cookies << " cookies";
“LOG”宏为日志输出关键字,“INFO”为严重性程度。
主要支持功能:
1, 参数设置,以命令行参数的方式设置标志参数来控制日志记录行为;
2, 严重性分级,根据日志严重性分级记录日志;
3, 可有条件地记录日志信息;
4, 条件中止程序。丰富的条件判定宏,可预设程序终止条件;
5, 异常信号处理。程序异常情况,可自定义异常处理过程;
6, 支持debug功能。可只用于debug模式;
7, 自定义日志信息;
8, 线程安全日志记录方式;
9, 系统级日志记录;
10, google perror风格日志信息;
11, 精简日志字符串信息。
开源代码托管
开源代码地址:https://github.com/google/glog
其实官方开源代码已经有大量demo可以参考了,也提供了VS可以直接打开编译的项目。
如何使用
1:把glog文件夹拷贝到源代码目录
2:在工程设置中添加附加包含目录(glog\include;)和附加库目录(glog\lib;),在附件依赖项中添加对应lib文件,一一对应关系如下:
MDd   libglog32MDd.lib
MD  libglog32MD.lib
MTd  libglog32MTd.lib
MT  libglog32MT.lib
建议使用MDd和MD方式,带上对应的dll(在glog\bin目录,需要时拷贝到bin文件输出目录)可以避免使用MTd,MT引起的内存泄露是值得的。
#include <iostream>#include <Windows.h>using namespace std;//包含glog头文件,建议放在stdafx.h中//#define GOOGLE_GLOG_DLL_DECL           // 使用静态库的时候用这个,不过我测试静态库有内存泄露,所以不推荐使用静态库#define GLOG_NO_ABBREVIATED_SEVERITIES#include "glog/logging.h"//获取当前程序的运行目录string GetAppPathA(){char szExePath[MAX_PATH] = {0};GetModuleFileNameA(NULL,szExePath,MAX_PATH);char *pstr = strrchr(szExePath,'\\');memset(pstr+1,0,1);string strAppPath(szExePath);return strAppPath;}void main(){//glog初始化google::InitGoogleLogging("重签程序");string strLogPath = GetAppPathA().append("LogInfo\\");CreateDirectoryA(strLogPath.c_str(),NULL);google::SetLogDestination(google::GLOG_INFO,strLogPath.c_str());//功能测试LOG(INFO)<<"log start...";//普通日志LOG(WARNING)<<"Warning log";//警告日志LOG(ERROR)<<"Error log";//错误日志int i = 4;LOG_IF(INFO,i == 4)<<"Log if Test";//以上就是我常用的几个日志函数了,当然还有很多更加强大的日志相关函数,大家如有有兴趣,可以参照官方给的示例使用,//开源代码地址:https://github.com/google/glogMessageBoxA(NULL,"Test Over",":)",MB_ICONINFORMATION);}

测试程序中,我使用的动态链接库方式。(Debug模式中代码生成为MDd,Release为MD)。lib是截止现在2015-11-04-21:35是最新的。采用VS2010编译,MTd,MT,MDd,MD方式编译在测试项目中都有提供。

效果如下:



以上是测试代码,完整工程下载链接:(VS2010)

http://download.csdn.net/detail/sunflover454/9241919



0 0
原创粉丝点击