当前位置: 首页 > news >正文

中国制造网外贸网站电工培训机构

中国制造网外贸网站,电工培训机构,网站群的建设,昆明 网站 制作1.什么是spdlog ①.spdlog是一款高效的C日志库,特别适用于使用C和需要引入日志库的项目。 ②.spdlog以极高的性能和零成本的抽象而著称,通过模板和内联函数实现零成本的抽象。 ③.spdlog支持异步和同步的日志输出和记录 日志的作用:追踪程…

1.什么是spdlog

①.spdlog是一款高效的C++日志库,特别适用于使用C++和需要引入日志库的项目。

②.spdlog以极高的性能和零成本的抽象而著称,通过模板和内联函数实现零成本的抽象。

③.spdlog支持异步和同步的日志输出和记录

日志的作用:追踪程序运行的状态,出现问题提供现场运行信息,分析性能瓶颈和潜在的系统故障

spdlog提供多种日志级别,如info、debug、trace、error、critical等。

2.同步日志和异步日志的区别

.同步日志:调用日志函数后,日志内容立即打印并落盘,当前线程阻塞等待日志完成。

.异步日志:调用日志函数后,日志内容被抛入队列,由其他线程在后台打印,当前线程立即返回。

③.多线程使用日志库与同步或异步无关,关键在于日志库是否线程安全。

3.spdlog的抽象模型

①.registry:注册器,单例管理多个logger。

②.logger:日志记录器,管理多个sink。

③.sink:日志接收器,具体负责将日志输出到目的地。

④.thread_pool:线程池,用于异步日志的输出。

4.如何创建logger??

工厂方法创建

    //使用工厂默认的auto logger = spdlog::stdout_color_mt<spdlog::async_factory>("conslole");logger->info("helloworldtoo!!");//直接infospdlog::get("conslole")->info("helloworldtootoo!!");//根据name  info

手动创建

    //自己定义的sinkauto sink1 =make_shared<spdlog::sinks::stdout_color_sink_mt>();auto sink2 =make_shared<spdlog::sinks::basic_file_sink_mt>("lion.txt");

方便携带多个sink

    auto logger1 =make_shared<spdlog::logger>("conslole1");logger1->sinks().push_back(sink1);//把sink1加入logger1->sinks().push_back(sink2);//把sink2加入spdlog::register_logger(logger1);//把logger1绑定在register里spdlog::get("conslole1")->info(("heloworldtootootoo!!"));//sink1 接收器 在终端输出//sink2 接收器 在输出到.txt文件里 

注册logger,目的是为了全局访问

5.如何自定义格式

class my_formatter_flag : public spdlog::custom_flag_formatter
{
public:void format(const spdlog::details::log_msg &, const std::tm &, spdlog::memory_buf_t &dest) override{std::string some_txt = "lion-flag";dest.append(some_txt.data(), some_txt.data() + some_txt.size());}std::unique_ptr<custom_flag_formatter> clone() const override{return spdlog::details::make_unique<my_formatter_flag>();}
};
    //formatter标识绑定auto formatter = make_unique<spdlog::pattern_formatter>();formatter->add_flag<my_formatter_flag>('*').set_pattern("[%n][%*][%^%l%$]%v");sink1->set_formatter(std::move(formatter));//sink1 --->formatter 自己添加的标识//sink2 --->自己手动定义的patternsink2->set_pattern("[%^%l%$]%v");

sink1使用了formatter标识

sink2使用了set_pattern

6.创建异步日志的方法总结

线程池在异步日志的应用

    spdlog::init_thread_pool(8292, 8);std::vector<spdlog::sink_ptr> sinks;sinks.push_back(sink1);sinks.push_back(sink2);auto logger_tp = std::make_shared<spdlog::async_logger>("tp", sinks.begin(), sinks.end(), spdlog::thread_pool(), spdlog::async_overflow_policy::overrun_oldest);logger_tp->info("hello thread pool");logger_tp->info("hello thread pool");logger_tp->flush();logger_tp->flush_on(spdlog::level::err);spdlog::flush_every(std::chrono::seconds(5));

综上所述,这段代码实现了一个异步日志记录系统,使用线程池来处理日志消息,将日志消息发送到多个日志接收器,并设置了不同的刷新策略来确保日志消息能够及时写入到日志接收器中。

http://www.cadmedia.cn/news/4687.html

相关文章:

  • cc0图片素材网站传播易广告投放平台
  • 网站维护与建设合同书智能营销系统
  • 网站建设合同的性质关键词优化的主要工具
  • 自助游网站开发分析报告百度入口提交
  • 页面设计要求北京网站优化常识
  • 长沙微信公众号开发东莞seo优化seo关键词
  • 中国第四冶金建设有限公司官方网站品牌营销推广策划公司
  • 吴江区建设用地申报网站网络推广合作协议范本
  • 在哪能学到网站建设专业网站运营需要多少钱
  • wordpress常用函数济南seo怎么优化
  • b2c知名网站在线生成html网页
  • 申请完域名如何建网站站长工具如何使用
  • 正规的专业高端网站建设广州网站推广软件
  • 网站建设怎么做账会计推广赚钱平台有哪些
  • 元邦物流网站建设公司优化是什么意思
  • 东莞做网站的游戏推广引流软件
  • 青州企业网站建设网络销售新手入门
  • 东营网站建设公司 网络易站长工具爱站
  • 网站建设要不要监理引流推广是什么意思
  • 表白网站源码大全sem推广和seo的区别
  • 医院网站建设 中企动力网络服务商怎么咨询
  • html个人源码seo网站推广的主要目的不包括
  • 金山区网站建设推广竞价托管公司
  • 《基层建设》在哪个网站收录的网页设计html代码大全
  • 杭州网站建设很棒小红书推广渠道
  • 自己建个网站做优化西安建站推广
  • 西宁网站建设嘉荐君博l百度竞价推广什么意思
  • 时时彩网站建设teafly行业关键词词库
  • 凤台做网站宁波seo推广推荐公司
  • 泰安的网站建设公司班级优化大师的优点