c++日志工具spdLog简单使用示例代码

spdlog直接引用头文件就可以使用,这一点还是比较方便的,也是刚入门使用,下面是在源码的示例代码基础上修改测试的代码:

#include <cstdio>
#include <iostream>
#include "spdlog/spdlog.h"
#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"void err_handler_example()
{spdlog::set_error_handler([](const std::string& msg){printf("*****Custom log error handler, %s*****%\n", msg.c_str());});
}int main(int , char *[])
{try {auto console_sink = 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] [%t] [%l] %v%$");//auto file_sink = std::make_shared<spdlog::sinks::basic_file_sink_mt>("logs/multisink.txt", false);auto file_sink = std::make_shared<spdlog::sinks::rotating_file_sink_mt>("logs/multisink.txt", 1048576, 3);file_sink->set_pattern("[%Y-%m-%d %H:%M:%S:%e] [%n] [%t] [%l] %v");file_sink->set_level(spdlog::level::debug);std::vector<spdlog::sink_ptr> sinks;sinks.push_back(console_sink);sinks.push_back(file_sink);//spdlog::logger *logger = new spdlog::logger("multi_sink", {console_sink, file_sink});auto logger = std::make_shared<spdlog::logger>("multi_sink", begin( sinks ), end( sinks ));//logger->set_level(spdlog::level::debug);#if 0  //也可以使用这种方式spdlog::sinks_init_list sink_list = { console_sink->sinks().front(), file_sink->sinks().front() };//创建一个新的日志对象,以上面两个日志对象作为初始化参数,即实现了同时输出 console 和 fileauto log_ptr = spdlog::create("loggername", sink_list);spdlog::register_logger( combined_logger );
#endiferr_handler_example();logger->warn("this should appear in both console and file");logger->info("this message should appear in file , not in console");//注册到spdlog里spdlog::register_logger(logger);auto test_logger = spdlog::get("multi_sink");test_logger->info("getlogger::helloworld");std::string msg = "hello world 2019.";logger->warn("spdlog: {}", msg);auto rotating_logger = spdlog::rotating_logger_mt("log_rotating", "logs/rotating.txt", 256, 2);for (int i = 0; i < 10; ++i)rotating_logger->info("{} * {} equals {:>10}", i, i, i*i);}catch (const spdlog::spdlog_ex &ex){std::cout<<"Log initialization faild"<<ex.what()<<std::endl;}}

个人微信服务号同步推送文章(微信公众号:fensnote):

c++日志工具spdLog相关推荐

  1. C++11日志之spdlog

    c++日志工具spdlog spdlog日志是纯头文件,使用起来比较方便.使用时只需要简单的初始化即可,这里对其初始化做了一个简单的封装,这样使用起来更加方便. 封装类代码 头文件 cspdlog.h ...

  2. 细说 Java 主流日志工具库

    点击上方"方志朋",选择"设为星标" 做积极的人,而不是积极废人 作者:静默虚空 juejin.im/post/5c8f35bfe51d4545cc650567 ...

  3. 细说Java主流日志工具库

    细说 Java 主流日志工具库 日志框架 java.util.logging (JUL) Log4j Logback Log4j2 Log4j vs Logback vs Log4j2 日志门面 co ...

  4. 【工具推荐】ELMAH——可插拔错误日志工具(转)

    出处:http://www.cnblogs.com/liping13599168/archive/2011/02/23/1962625.html 今天看到一篇文章(构建ASP.NET网站十大必备工具( ...

  5. Android Studio 单刷《第一行代码》系列 02 —— 日志工具 LogCat

    前情提要(Previously) 本系列将使用 Android Studio 将<第一行代码>(书中讲解案例使用Eclipse)刷一遍,旨在为想入坑 Android 开发,并选择 Andr ...

  6. iOS轻量分组日志工具 Log4OC

    OC分级日志工具,支持4种日志级别,提供两种持久化方案 源码地址: github.com/FinderTiwk/- 使用 #import "Log4OC.h"//DEBUGLog( ...

  7. linux 系统后门检测工具,Linux系统的各种后门和日志工具详细介绍[2]

    chfn 提升本地普通用户权限的程序 运行chfn 在它提示输入新的用户名时 如果用户输入rookit密码 他的权限就被提升为root chsh 提升本地用户权限的程序 运行chsh 在它提示输入新的 ...

  8. Android入门(三) | Android 的日志工具 Logcat

    文章目录 日志工具类 android.util.Log Logcat 中的过滤器 日志工具类 android.util.Log Log 从属日志工具类 android.util.Log ,该类提供了五 ...

  9. .NET日志工具介绍

    原文:http://www.cnblogs.com/maxliu/archive/2012/08/03/2621088.html 最近项目需要一个日志工具来跟踪程序便于调试和测试,为此研究了一下.NE ...

最新文章

  1. 随笔:项目感想、知识总结、未来展望
  2. 【计算机视觉】背景建模之PBAS
  3. shellcode模板(使用hash获取API)
  4. 用户控件 自定义控件_新的自定义控件:TaskProgressView
  5. linux top 命令可视化_Linux 使用 top 命令查看系统的运行情况
  6. MySql 一条更新语句是如何执行的? MySql杂谈、MySql WAL 技术
  7. SpringBoot配置Profile以及配置文件的加载位置
  8. 开源库UITableView+FDTemplateLayoutCell学习
  9. 公司部分断电,这些人就没法干活?
  10. C/C++[codeup 1923]排序
  11. [思维导图学习五] 思维导图在企业培训中的应用[转]
  12. 获取China大陆IP段的范围
  13. 本草纲目pdf彩图版下载_本草纲目pdf下载|本草纲目彩色插图版PDF完整版_ - 极光下载站...
  14. Android悬浮窗的简单实现
  15. Matlab二维图形绘制与图形处理
  16. BZOJ1499: [NOI2005]瑰丽华尔兹
  17. 利用ARCHPR明文攻击对zip口令进行破解以及报错解决
  18. 设计模式-策略模式-java-中文版
  19. Flask04——请求上下文和应用上下文
  20. Forming a Magic Square

热门文章

  1. 内外网通过公网IP访问DMZ主机
  2. 基于Snort的入侵检测系统_相关论文
  3. SQL——数据库使用规范(入门规范)
  4. 简单聊聊SOA和微服务
  5. 编译与调试以及makefile
  6. 游戏党注意了,超80款Steam游戏可在优麒麟上畅玩
  7. CSS中的表格2️⃣之合并/拆分单元格以及单元格中在存放表格(跨行或者跨列)
  8. 界面相当华丽HTC G11西安报价2450元
  9. 可以在linux下运行的u盘制作工具,启动U盘创建工具(LiLi USB Creator)
  10. Java-反射概述、操作、作用(含有代码演示)