博客
关于我
c++日志工具spdLog
阅读量:398 次
发布时间:2019-03-05

本文共 2210 字,大约阅读时间需要 7 分钟。

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

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

#include 
#include
#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
(); 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
("logs/multisink.txt", false); auto file_sink = std::make_shared
("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
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
("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 和 file auto log_ptr = spdlog::create("loggername", sink_list); spdlog::register_logger( combined_logger );#endif err_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"<
<

 

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

转载地址:http://ahgg.baihongyu.com/

你可能感兴趣的文章
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>