C++日志

0 资料

1 spdlog

1.1 简介

spdlog是一个用C++11编写的高性能日志库,优点:

复制代码
- 高性能
- 用法类似python的logging

1.2 安装

plain 复制代码
#include "spdlog/spdlog.h"

int main() {
	//Use the default logger (stdout, multi-threaded, colored)
  
  spdlog::info("hello spd");
  spdlog::info("hello {}, {}", "shuo", 29);   
  
  return 0;
}
  • 保存并退出,其文件目录如下
plain 复制代码
$ tree -L 2
.
|-- main.cpp
`-- spdlog
    |-- include
  • 编译测试代码(注意要用C++11的标准)
    • g++ --std=c++11 -I spdlog/include main.cpp

1.3 使用

1.3.1 基本使用

plain 复制代码
#include <iostream>
#include "spdlog/spdlog.h"
#include "spdlog/sinks/stdout_color_sinks.h"  //支持输出到标准终端
#include "spdlog/sinks/basic_file_sink.h" // 支持保存到基础文档
#include "spdlog/sinks/rotating_file_sink.h" // 支持保存成滚动文档

int main(int, char* [])
{
    try 
    {
    		// 1、将日志打印到标准输出中
        auto console = spdlog::stdout_color_mt("console");
        console->set_level(spdlog::level::warn);  //设置日志记录器的输出日志等级
        console->info("Welcome to spdlog");
        
        // 2、将日志保存到文本中 (not rotated)
        auto my_logger = spdlog::basic_logger_mt("basic_logger", "logs/basic.txt");
        my_logger->info("hello");
        
        // 3、将文字保存到一个迭代的文本中,改文本最大5M,最多有3个文本
        auto file_logger = spdlog::rotating_logger_mt("file_logger", "myfilename", 1024 * 1024 * 5, 3);
        file_logger->info("hello file");
    }
    catch (const spdlog::spdlog_ex& ex)
    {
        std::cout << "Log initialization failed: " << ex.what() << std::endl;
    }
}

1.3.2 多个日志记录器共享一个日志文件

plain 复制代码
#include "spdlog/sinks/daily_file_sink.h"
#include "spdlog/spdlog.h"
#include <iostream>
int main(int, char *[]) {
	// 设置文件异步共享终端
  auto daily_sink = std::make_shared<spdlog::sinks::daily_file_sink_mt>("logfile", 23, 59);
  // 创建日志异步发生器
  auto net_logger = std::make_shared<spdlog::logger>("net", daily_sink);
  auto hw_logger = std::make_shared<spdlog::logger>("hw", daily_sink);

  // 设置各个发生器的日志等级 (error, warn, info, debug)
  net_logger->set_level(spdlog::level::info);
  hw_logger->set_level(spdlog::level::debug);

  // 全局登记发生器,使之能使用spdlog::get(logger_name)的方式在其他地方被获取
  spdlog::register_logger(net_logger);

  net_logger->info("hello net_logger");
  hw_logger->info("hello hw_logger");
}

1.3.3 通过spdlog::get("...")来访问一个已经创建的logger

spdlog对于每个线程,都维护着一个全局的日志发生器,所有日志发生器在产生的时候都会被自动注册。在程序的其他地方,可以使用** auto 指针 = spdlog::get(日志发生器名称 );来获取改日志发生器的指针。如果该日志发生器不存在,则会返回空指针。因此,可以使用if(指针)**来判断是否有该日志发生器。

plain 复制代码
class logger_get
{
    private:
    std::shared_ptr<spdlog::logger> _logger = spdlog::get("console"); 
    
    public:
    void print_hello()
    {
        _logger->info("helloworld");
        return;
    }
};

然后在main函数中试着调用这个类

plain 复制代码
int main(int, char* [])
{
  ...

  logger_get test;
  test.print_hello();
}
相关推荐
CC__xy23 分钟前
04 类型别名type + 检测数据类型(typeof+instanceof) + 空安全+剩余和展开(运算符 ...)简单类型和复杂类型 + 模块化
开发语言·javascript·harmonyos·鸿蒙
青草地溪水旁29 分钟前
UML函数原型中stereotype的含义,有啥用?
c++·uml
萤丰信息34 分钟前
技术赋能安全:智慧工地构建城市建设新防线
java·大数据·开发语言·人工智能·智慧城市·智慧工地
青草地溪水旁36 分钟前
UML函数原型中guard的含义,有啥用?
c++·uml
Pocker_Spades_A1 小时前
飞算JavaAI家庭记账系统:从收支记录到财务分析的全流程管理方案
java·开发语言
CHEN5_022 小时前
【Java基础常见辨析】重载与重写,深拷贝与浅拷贝,抽象类与普通类
java·开发语言
Despacito0o2 小时前
C语言基础:变量与进制详解
java·c语言·开发语言
nightunderblackcat3 小时前
进阶向:人物关系三元组,解锁人物关系网络的钥匙
开发语言·python·开源·php
光头闪亮亮3 小时前
C++凡人修仙法典 - 宗门版-上
c++
光头闪亮亮3 小时前
C++凡人修仙法典 - 宗门版-下
c++