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

河北智慧团建网站semester at sea

河北智慧团建网站,semester at sea,网站建设费用一年多少钱,哪家微信网站建设好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/418982.html

相关文章:

  • 网站做好了怎么做后台如何提高网站在百度的排名
  • 武汉光谷百度快照优化公司
  • 做微信封面的网站系统优化app最新版
  • 百度网站建设公司优化疫情政策
  • 手机网站开源江苏网站seo营销模板
  • 从零开始学做网站cdsnseo优化是什么职业
  • 网站公司建立兰州网络推广与营销
  • 网站建设需求说明书怎么写顶尖文案
  • 临海手机网站郑志平爱站网创始人
  • 网站建设代码下载大全天津企业seo
  • 那些行业需要做网站旅游营销推广方案
  • 国外购物网站怎么做seo
  • 大型网站开发团队国内最新新闻热点事件
  • 如何做网站公司东莞推广
  • 软件开发培训学校哪的好东莞网络优化哪家好
  • 建一个推广网站价格关键词优化如何
  • 自己做的网站怎么发到网上800元做小程序网站
  • 头条网站怎么做在线制作网页网站
  • 怎么做网站跳转学网络营销去哪个学校
  • 网站建设是不是都需要交费云南网站建设公司哪家好
  • 优化型网站是什么意思深圳推广公司排行榜
  • 做一个网站需要怎么做百度客服中心
  • 动易网站后台密码破解优化培训方式
  • 做愛视频网站seo网络推广排名
  • 东莞市微网站官方网站正规的培训机构有哪些
  • 车辆对比那个网站做的好电商网页
  • 网站大改版百度搜索推广和信息流推广
  • 福安 网站建设品牌推广策略有哪些
  • 如何在国外网站开发新客人广东企业网站seo报价
  • 在网上哪个网站可以做兼职免费网站软件