c++库:日志-glog

google 的一个 c++ 开源日志系统

安装

git clone https://github.com/google/glog.git
mkdir build && cd build
cmake -DGFLAGS_NAMESPACE=google -DCMAKE_CXX_FLAGS=-fPIC …
make && sudo make install

开启或关闭

1. 使用glog之前必须初始化:
google::InitGoogleLogging(argv[0]);
2. 结束glog时必须关闭库:
google::ShutdownGoogleLogging();

输出

1. 设置日志文件保存目录(目录必须存在)
方法1:必须在初始化库之前调用
FLAGS_log_dir = "/home/ubuntu/Desktop/log";
指定log文件在/home/ubuntu/Desktop/log目录下,此时不同级别的日志保存在不同文件中(应用名.日志保存路径.日志级别.年月日-时分秒)
方法2:(此方法会覆盖方法1)
google::SetLogDestination(google::INFO, "/home/ubuntu/Desktop/log/log_"); //INFO级别的日志目录
google::SetLogDestination(google::ERROR,"/home/ubuntu/Desktop/log/log_"); //ERROR级别的日志目录
google::SetLogDestination(google::WARNING,"/home/ubuntu/Desktop/log/log_");//WARNING级别的日志目录
指定log文件在/home/ubuntu/Desktop/log目录下,并且日志文件名以log_开头,可以指定不同级别的日志到一个文件中(前缀年月日-时分秒)
注意:
	a. 当日志输出时才创建文件
	b. 每运行一次应用都会重新创建一个日志文件(原来的文件不删除)
2. 输出到终端
google::SetStderrLogging(google::INFO); //大于INFO级别的都输出到标准输出的时候
3. 错误级别
enum SeverityLevel { google::INFO = 0, google::WARNING = 1, google::ERROR = 2, google::FATAL = 3, };
4. 日志输出
LOG(INFO) << "info test" << "hello world!"; //输出一个Info日志
LOG(WARNING) << "warning test"; //输出一个Warning日志
LOG(ERROR) << "error test"; //输出一个Error日志
LOG(FATAL) << "fatal test"; //输出一个Fatal日志,这是最严重的日志并且输出之后会中止程序
5. 条件输出
//当条件满足时输出日志
LOG_IF(INFO, 1 > 0) << "LOG_IF";
//每N次输出当前日志(输出1,1+N,1+2N ……的日志,其它的忽略)
LOG_EVERY_N(INFO, N) << google::COUNTER << " LOG_EVERY_N";
//条件满足并且每N次输出当前日志
LOG_IF_EVERY_N(INFO, (1 > 0), N) << google::COUNTER << " LOG_IF_EVERY_N";
//只输出前N条日志,后面的都不输出
LOG_FIRST_N(INFO, N) << google::COUNTER << " LOG_FIRST_N";
6. 参数设置
FLAGS_logtostderr = false; //设置日志消息是否转到标准输出而不是日志文件
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; //设置是否在磁盘已满时避免日志记录到磁盘

示例

#include <glog/logging.h>
int main(int argc, char *argv[])
{
FLAGS_logtostderr = false; //设置日志消息是否转到标准输出而不是日志文件
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; //设置是否在磁盘已满时避免日志记录到磁盘
//初始化
google::InitGoogleLogging(argv[0]);
//指定目录下
google::SetLogDestination(google::INFO, “/home/ubuntu/Desktop/log/log_”); //INFO级别的日志目录
google::SetLogDestination(google::ERROR,"/home/ubuntu/Desktop/log/log_"); //ERROR级别的日志目录
google::SetLogDestination(google::WARNING,"/home/ubuntu/Desktop/log/log_");//WARNING级别的日志目录
google::SetStderrLogging(google::INFO); //大于INFO级别的都输出到标准输出的时候
LOG(INFO) << “info test” << “hello world!”;//输出一个Info日志
LOG(WARNING) << “warning test”; //输出一个Warning日志
LOG(ERROR) << “error test”; //输出一个Error日志
//LOG(FATAL) << “fatal test”; //输出一个Fatal日志,这是最严重的日志并且输出之后会中止程序
for(int i=0; i< 10;i++){
//当条件满足时输出日志
LOG_IF(INFO, 1 > 0) << “LOG_IF”;
//每2次输出当前日志(输出1,3,5……的日志)
LOG_EVERY_N(INFO, 2) << google::COUNTER << " LOG_EVERY_N";
//条件满足并且每2次输出当前日志
LOG_IF_EVERY_N(INFO, (1 > 0), 2) << google::COUNTER << " LOG_IF_EVERY_N";
//只输出前两条日志,后面的都不输出
LOG_FIRST_N(INFO, 2) << google::COUNTER << " LOG_FIRST_N";
}
QApplication a(argc, argv);
MainWindow w;
w.show();
google::ShutdownGoogleLogging(); //关闭
return a.exec();
}

附件是VS2010的工程,C++日志类,谷歌的东西,很好用,也很强大哦! 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 #include 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/glog MessageBoxA(NULL,"Test Over",":)",MB_ICONINFORMATION); } 测试程序中,我使用的动态链接方式。(Debug模式中代码生成为MDd,Release为MD)。lib是截止现在2015-11-04-21:35是最新的。采用VS2010编译,MTd,MT,MDd,MD方式编译在测试项目中都有提供。 博文地址: http://blog.csdn.net/sunflover454/article/details/49643625
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值