热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C++11日志之spdlog

c日志工具spdlogspdlog日志是纯头文件,使用起来比较方便。使用时只需要简单的初始化即可,这里对其初始化做了一个简单的封装,这样

c++日志工具spdlog

spdlog日志是纯头文件,使用起来比较方便。使用时只需要简单的初始化即可,这里对其初始化做了一个简单的封装,这样使用起来更加方便。

封装类代码


头文件

cspdlog.h

#ifndef _CSPDLOG_H_
#define _CSPDLOG_H_#include "spdlog/spdlog.h"
#include "spdlog/fmt/bin_to_hex.h"
#include
#include class CSpdlog
{
protected:CSpdlog();~CSpdlog();static CSpdlog *m_instance;public:static CSpdlog *GetInstance();void Init(const std::string & name,const std::string &logPath, std::size_t max_size&#61;1048576, std::size_t max_file &#61; 2);void SetConsoleLogLevel(spdlog::level::level_enum log_level);void SetFileLogLevel(spdlog::level::level_enum log_level);private:std::vector<spdlog::sink_ptr> m_sinks;std::shared_ptr<spdlog::logger> m_logger;
};#endif

源文件

cspdlog.cpp

#include "cspdlog.h"#include
#include
#include "spdlog/sinks/stdout_color_sinks.h" // or "../stdout_sinks.h" if no color needed
#include "spdlog/sinks/basic_file_sink.h"
#include "spdlog/sinks/rotating_file_sink.h"CSpdlog::CSpdlog()
{}CSpdlog::~CSpdlog()
{}void CSpdlog::Init(const std::string & name, const std::string &log_path, std::size_t max_size, std::size_t max_file )
{try { auto console_sink &#61; std::make_shared<spdlog::sinks::stdout_color_sink_mt>();console_sink->set_level(spdlog::level::debug);console_sink->set_pattern("%^[%Y-%m-%d %H:%M:%S:%e] [%n] [tid: %t] [%l] %v%$");std::string logFile &#61; log_path &#43; "/" &#43; name &#43; ".txt";//auto file_sink &#61; std::make_shared("logs/multisink.txt", false);auto file_sink &#61; std::make_shared<spdlog::sinks::rotating_file_sink_mt>(logFile, max_size, max_file);file_sink->set_pattern("[%Y-%m-%d %H:%M:%S:%e] [%n] [tid: %t] [%l] %v");file_sink->set_level(spdlog::level::warn);m_sinks.push_back(console_sink);m_sinks.push_back(file_sink);//spdlog::logger *logger &#61; new spdlog::logger("multi_sink", {console_sink, file_sink});m_logger &#61; std::make_shared<spdlog::logger>(name, begin( m_sinks ), end( m_sinks ));//spdlog::set_error_handler([](const std::string& msg){printf("*****Custom log error handler, %s*****%\n", msg.c_str());});//注册到spdlog里spdlog::register_logger(m_logger);//m_logger->info("log init done.");m_logger->flush_on(spdlog::level::level_enum::warn); }catch (const spdlog::spdlog_ex &ex){std::cout<<"Log initialization faild"<<ex.what()<<std::endl;}
}void CSpdlog::SetConsoleLogLevel(spdlog::level::level_enum log_level)
{m_logger->set_level(log_level);
}void CSpdlog::SetFileLogLevel(spdlog::level::level_enum log_level)
{m_sinks[1]->set_level(log_level);
}CSpdlog* CSpdlog::m_instance &#61; NULL;CSpdlog* CSpdlog::GetInstance()
{if ( m_instance &#61;&#61; NULL ){m_instance &#61; new CSpdlog;}return m_instance;
}

测试主程序

#include
#include
#include
#include using namespace std;int main()
{CSpdlog::GetInstance()->Init("test","./log"); //初始化日志CSpdlog::GetInstance()->SetConsoleLogLevel(spdlog::level::debug); //设置终端界面输出级别CSpdlog::GetInstance()->SetFileLogLevel(spdlog::level::warn); //设置log文件输出级别auto logger &#61; spdlog::get("test"); //获取日志句柄logger->warn("test start.");int counter &#61; 0; while(1){logger->debug("debug msg, counter: {}",counter);logger->info("info msg, counter: {}",counter);logger->warn("warn msg, counter: {}",counter);logger->error("error msg, counter: {}",counter);logger->critical("critical msg, counter: {}",counter);logger->trace("trace msg, counter: {}",counter);usleep(500000);}return 0;
}

编译运行

我的通用Makefile

#通用makefile
#文件目录
DEBUG_DIR&#61;.
SRC_DIR&#61;.
INC_DIR&#61;. ./spdlogSRC&#61;$(wildcard $(SRC_DIR)/*.cpp ) #源文件
OBJS&#61;$(patsubst $(SRC_DIR)/%.cpp,$(DEBUG_DIR)/%.o,$(SRC))#目标文件名
TARGET&#61;test
INSTALL_PATH ?&#61; .#修改编译器
ARCH ?&#61;
CC&#61;$(ARCH)gcc
CPP&#61;$(ARCH)g&#43;&#43;
AR&#61;$(ARCH)ar
STRIP&#61;$(ARCH)stripCFLAGS &#43;&#61; -Wall -std&#61;c&#43;&#43;11
LDFLAGS &#43;&#61; -lpthreadCFLAGS &#43;&#61; $(foreach dir,$(INC_DIR),-I$(dir))all:$(TARGET)
$(TARGET): $(OBJS)$(CPP) $(OBJS) -o $&#64; $(CFLAGS) $(LDFLAGS)$(STRIP) $(TARGET)
#cp $(TARGET) $(INSTALL_PATH)$(DEBUG_DIR)/%.o: $(SRC_DIR)/%.cpp$(CPP) $(CFLAGS) -c $< -o $&#64; #&#64;echo $(SRC)
#&#64;echo $(OBJS)clean:-rm $(OBJS) $(LIB_TARGET)

编译

make
g&#43;&#43; -Wall -std&#61;c&#43;&#43;11 -I. -I./spdlog -c cspdlog.cpp -o cspdlog.o
g&#43;&#43; -Wall -std&#61;c&#43;&#43;11 -I. -I./spdlog -c main.cpp -o main.o
g&#43;&#43; ./cspdlog.o ./main.o -o test -Wall -std&#61;c&#43;&#43;11 -I. -I./spdlog
strip test

运行

console输出&#xff1a;
日志输出
文件输出&#xff1a;

$cat log/test.txt
[2021-08-17 15:30:59:526] [test] [tid: 20418] [warning] test start.
[2021-08-17 15:30:59:527] [test] [tid: 20418] [warning] warn msg, counter: 0
[2021-08-17 15:30:59:528] [test] [tid: 20418] [error] error msg, counter: 0
[2021-08-17 15:30:59:529] [test] [tid: 20418] [critical] critical msg, counter: 0
[2021-08-17 15:31:00:031] [test] [tid: 20418] [warning] warn msg, counter: 0
[2021-08-17 15:31:00:032] [test] [tid: 20418] [error] error msg, counter: 0
[2021-08-17 15:31:00:032] [test] [tid: 20418] [critical] critical msg, counter: 0
[2021-08-17 15:31:00:533] [test] [tid: 20418] [warning] warn msg, counter: 0
[2021-08-17 15:31:00:533] [test] [tid: 20418] [error] error msg, counter: 0
[2021-08-17 15:31:00:534] [test] [tid: 20418] [critical] critical msg, counter: 0

测试源代码以上传码云

地址&#xff1a;
https://gitee.com/fensnote/demo_code/tree/master/cpp/spdlog

微信公众号


fensnote
微信公众号


推荐阅读
  • DescriptionclickmeSolution套路的状压期望DP题。。。考虑倒退期望:设fi,jrolepresentationstyleposi ... [详细]
  • 题目描述Takuru是一名情报强者,所以他想利用他强大的情报搜集能力来当中间商赚差价。Takuru的计划是让Hinae帮他去市场上买一个商品,然后再以另一个价格卖掉它。Takur ... [详细]
  • 本文介绍了GTK+中的GObject对象系统,该系统是基于GLib和C语言完成的面向对象的框架,提供了灵活、可扩展且易于映射到其他语言的特性。其中最重要的是GType,它是GLib运行时类型认证和管理系统的基础,通过注册和管理基本数据类型、用户定义对象和界面类型来实现对象的继承。文章详细解释了GObject系统中对象的三个部分:唯一的ID标识、类结构和实例结构。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文主要介绍了gym102222KVertex Covers(高维前缀和,meet in the middle)相关的知识,包括题意、思路和解题代码。题目给定一张n点m边的图,点带点权,定义点覆盖的权值为点权之积,要求所有点覆盖的权值之和膜qn小于等于36。文章详细介绍了解题思路,通过将图分成两个点数接近的点集L和R,并分别枚举子集S和T,判断S和T能否覆盖所有内部的边。文章还提到了使用位运算加速判断覆盖和推导T'的方法。最后给出了解题的代码。 ... [详细]
  • P2765魔术球问题这道题的思路实在是太罕见了,所以发一篇blog从某一新放入的球开始看起1.放入原来的柱子上2.放入新的柱子并将每个点进行拆点࿰ ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • 预备知识可参考我整理的博客Windows编程之线程:https:www.cnblogs.comZhuSenlinp16662075.htmlWindows编程之线程同步:https ... [详细]
  • PHP反射API的功能和用途详解
    本文详细介绍了PHP反射API的功能和用途,包括动态获取信息和调用对象方法的功能,以及自动加载插件、生成文档、扩充PHP语言等用途。通过反射API,可以获取类的元数据,创建类的实例,调用方法,传递参数,动态调用类的静态方法等。PHP反射API是一种内建的OOP技术扩展,通过使用Reflection、ReflectionClass和ReflectionMethod等类,可以帮助我们分析其他类、接口、方法、属性和扩展。 ... [详细]
  • 前言很好的一道卡特兰数入门题,不板也不难题目HDU讲解括号匹配是经典的卡特兰数问题首先我们把无解与唯一解的情况特判出来,再考虑问题传统的卡特兰数的括号匹配对应的模型为从$(0,0) ... [详细]
  • 一文了解Python collections模块中的deque用法[python头条资讯]
    Python中文网有大量免费的Python入门教程,欢迎大家来学习。collections是Python内建的一个集合模块,deque是双边队列,具有队列和栈的性质,在list的基 ... [详细]
  • 796.[APIO2012]派遣在一个忍者的帮派里,一些忍者们被选中派遣给顾客,然后依据自己的工作获取报偿。在这个帮派里,有一名忍者被称之为Master。 ... [详细]
author-avatar
小古
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有