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
- C++日志类libglog使用
- C语言日志类
- Object-C使用NSLog打印日志
- c语言日志工具-zlog的使用
- C#(2)-------使用Log4Net记录日志
- Glog "libglog cannot open shared object file"
- 文件日志类(WIN32 , C++)
- Windows 日志记录类(c++)
- C程序的日志类
- 【C++】添加写日志类
- [glog]_[C/C++]_[使用glog来记录日志]
- Weblogic 12c 运行使用Slf4j日志框架应用解决方案
- Objective C Log日志提高 预定义宏使用
- C语言日志操作类实例
- C语言封装线程与日志类
- 安卓-打印日志及日志工具类使用
- logback使用日志工具类静态方法打印日志
- [C/C++]简单的C++日志操作类
- ajax对象使用的简单实例
- 仿函数
- 在中国爱国企业家联盟我们应微笑应对生活
- ViewPager
- 排列序号
- C++日志类libglog使用
- 二维几何常用模板
- Floyd求最小环 hdu1599 find the mincost route
- Android静态注册广播receiver检测WIFI连接状况变化
- java基础关于线程
- 组成最大多位数
- 命令上的命令
- 神奇的λ-calculus
- 字符流中第一个不重复的字符(哈希表+vecor+剑指offer)