文章目录
安装
- 更新包列表,安装glog
ssh
sudo apt-get update
sudo apt-get install libgoogle-glog-dev
配置
- 采用
cmakelist
的话,直接在target_link_libraries
中加入glog
即可,无需多做处理。
使用
cpp
#include "glog/logging.h"
void initGlog(const char *arg)
{
auto ErrorCallback = [](const char *data, int size)
{ std::string ss(data, size - 1);
LOG(ERROR) << ss; };
google::InitGoogleLogging(arg); // 函数来初始化glog
google::InstallFailureSignalHandler(); // 当程序遇到如SIGSEGV(段错误)这样的致命信号时,glog会打印出当前的堆栈跟踪。
google::InstallFailureWriter(ErrorCallback); // 当程序失败时,ErrorCallback 将被调用,从而记录错误信息。
FLAGS_alsologtostderr = true; // 除了将日志信息写入文件之外,还会将日志信息输出到标准错误(stderr)。
FLAGS_colorlogtostderr = true; // 让输出到标准错误的日志信息带有颜色,便于区分不同的日志级别。
FLAGS_logbuflevel = google::INFO; // 日志缓冲区中的日志级别至少为INFO,低于INFO级别的日志将被立即输出,而INFO及以上级别的日志可能会被缓冲。
mkdir("./logs", S_IRWXU | S_IRWXG | S_IRWXO); // 使用 mkdir 系统调用创建一个名为 logs 的目录,用于存放日志文件
FLAGS_log_dir = "./logs"; // 设置 FLAGS_log_dir 标志,指定日志文件的存放目录为 ./logs
}
int main(int argc, char* argv[])
{
initGlog(argv[0]);
// 输出日志
LOG(INFO) << "This is an info message";
LOG(WARNING) << "This is a warning message";
LOG(ERROR) << "This is an error message";
google::ShutdownGoogleLogging();
return 0;
}