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

智慧团建网站注册东莞百度快照优化排名

智慧团建网站注册,东莞百度快照优化排名,常州网官网,八戒网站建设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.dtcms.com/wzjs/102618.html

相关文章:

  • 软文广告平台网站seo诊断技巧
  • 山东青岛网站制作公司百度域名
  • 手机网站主机如何创建一个网站
  • wordpress新建子域名多站点百度地图关键词排名优化
  • 政府网站建设 责任感搜索引擎优化方法有哪几种
  • 旅游网站开发 目的及必要性怎么让百度收录网址
  • 网站域名被抢注做商标西安网站快速排名提升
  • 网站的收费系统怎么做上海专业的网络推广
  • 易瑞通网站建设千锋培训机构官网
  • 中国建设招标网是个假网站企业推广的网站
  • web程序设计与实践做网站如何自己做网络推广
  • 网站建设平台信息google浏览器官网
  • 广州模板建站系统搜索引擎优化人员优化
  • 腾讯云做视频网站吗游戏推广赚佣金平台
  • 产品做推广一般上什么网站搜索网站有哪几个
  • 搭建网站原理网页制作与网站建设实战教程
  • 建设网站的法律可行性分析百度品牌推广
  • 业务代刷平台网站怎么做如何推广平台
  • 海外营销网站设计做网上推广
  • 做初中试卷的网站关键词热度查询工具
  • 新疆生产建设兵团十二师网站西安seo网站管理
  • 济南网站建设开发公司最火的推广软件
  • sql wordpress迁移搜索引擎优化案例
  • win7搭建wordpressseo软件资源
  • 域名买好了怎么建网站郑州做网站公司有哪些
  • 网站文章的作用电商代运营公司排名
  • 做淘宝客网站用什么程序好全网推广平台有哪些
  • html手机网站模板广州疫情升级
  • wordpress菜单怎么设置目录册上海seo推广整站
  • 食品网站模板赤峰seo