首页>行业>正文
天天热议:#Spdlog# Spdlog的编译与使用
2023-01-12 23:07:41    来源:程序员客栈

“文章所涉及内容更多来自网络,在此声明,并感谢知识的贡献者!”


(资料图片)

CMake—

Cmake简介

CMake是一个跨平台的编译(Build)工具,可以用简单的语句来描述所有平台的编译过程。

CMake能够输出各种各样的makefile或者project文件,能测试编译器所支持的C++特性,类似UNIX下的automake。

CMake 不仅可以编译源代码、制作程序库、产生适配器(wrapper)、还可以用任意的顺序建构执行档。CMake 支持 in-place 建构(二进档和源代码在同一个目录树中)和 out-of-place 建构(二进档在别的目录里),因此可以很容易从同一个源代码目录树中建构出多个二进档。CMake 也支持静态与动态程式库的建构。

https://blog.csdn.net/weixin_45525272/article/details/122053959

下载并安装Cmake

https://cmake.org/download/

Cmake编译教程

https://www.bilibili.com/read/cv14249845

https://blog.csdn.net/m0_61812914/article/details/127952081

Eigen—

Eigen简介:

Eigen是一个高层次的C ++库,有效支持线性代数,矩阵和矢量运算,数值分析及其相关的算法。

下载Eigen源码

https://eigen.tuxfamily.org/index.php?title=Main_Page

https://gitlab.com/libeigen/eigen/-/releases/3.4.0

编译安装Eigen源码

https://www.likecs.com/show-204786214.html#sc=2625

https://blog.csdn.net/OOFFrankDura/article/details/103586893

PCL—

PCL简介

PCL(Point CloudLibrary)是在吸收了前人点云相关研究基础上建立起来的大型跨平台开源C++编程库,它实现了大量点云相关的通用算法和高效数据结构,涉及到点云获取、滤波、分割、配准、检索、特征提取、识别、追踪、曲面重建、可视化等。支持多种操作系统平台,可在Windows、Linux、Android、Mac OS X、部分嵌入式实时系统上运行。如果说OpenCV是2D信息获取与处理的结晶,那么PCL就在3D信息获取与处理上具有同等地位,PCL是BSD授权方式,可以免费进行商业和学术应用。

https://blog.csdn.net/qq_41951923/article/details/103375681

https://blog.csdn.net/expert_joe/article/details/123342098

下载并安装PCL

https://github.com/PointCloudLibrary/pcl/releases/tag/pcl-1.8.1

下载PCL源码

http://pointclouds.org/documentation/index.html

编译PCL

https://blog.csdn.net/weixin_43186817/article/details/103469057

https://blog.csdn.net/luolaihua2018/article/details/116919716

https://blog.csdn.net/hanxue20100/article/details/116654750

https://blog.csdn.net/weixin_44456692/article/details/113508167

https://blog.csdn.net/whutt_/article/details/122756505

https://blog.csdn.net/m0_61812914/article/details/127952081

Spdlog编译—

Spdlog简介

spdlog是一款优秀的基于C++11的轻量级的日志管理库,使用时只需要引入头文件即可。将记录日志交给spdlog,事半功倍。

下载spdlog源码

https://github.com/gabime/spdlog

编译spdlog源码

使用Cmake GUI编译spdlog

-在spdlog源码中新建build文件夹

-在Cmake Gui 配置项目的编译信息

-配置VS的属性

-点击Generate,生成spdlog.sln

-vs 2017编译生成 spdlog.dll

生成的目标文件:

spdlog_project\spdlog-1.x\build\Release\spdlog.lib

Spdlog调用—

-新建项目

-创建第三方库文件夹

-将编译生成的spdlog.lib文件复制到第三方库ThirdLib文件夹

-将spdlog源码中include文件夹下的spdlog文件夹复制到ThirdLib文件夹

-配置spdlog库的引用信息

https://www.jianshu.com/p/64bcc1fe3fab

-在自定义类中引用spdlog

-运行效果

Spdlog教程—

Spdlog特性

-非常快

-只包含头文件

-无需依赖第三方库

-支持跨平台 - Linux /Windows on 32/64 bits

-支持多线程

-可对日志文件进行循环输出

-可每日生成日志文件

-支持控制台日志输出

-可选的异步日志

-支持日志输出级别

-可自定义日志格式

Spdlog 功能:

Spdlog只有一个管家register,管家按照日志名字管理所有日志(即文件日志和控制台日志),管家有提供很多服务,主要有输出日志级别,刷新文件日志方式,设置日志格式等

Spdlog 结构:

spdlog可以分成三级结构,从上而下是logger registry、logger、sink,其各自功能如下:

logger registry(日志管理器):负责管理所有的logger,用户建立的所有logger都会在registry处进行登记然后统一管理

logger(日志记录器):是用户直接操作的对象,通过操作logger进行日志逻辑的生成

sink(日志记录器槽):受logger控制,执行具体的动作(动作包括写入日志文件/输出到控制台)

一个logger registry管多个logger,一个logger管多个sink。logger registry中的logger是通过name进行对应的。后面使用的时候可以直接通过名称获取对应的日志对象。

有了这种层级结构,在代码调用的时候,logger的每个操作都会下顺到sink层面,调用sink的对象。比如像一些set_pattern()和set_level()。

日志库的目的就是把日志信息写到指定地方。从上面对于结构的功能描述,sink才是真正操作日志进行写操作的结构,那sink可以把日志信息写到哪里呢?主要有三个去向:  1)控制台输出(stdout)——默认输出方式  2)日志文件  3)数据库或其他外部实体

Spdlog 存储:

spdlog中提供了以下几种存放方式:

1)当天日志(spdlog::daliy_logger):记录当天的所有日志,但在指定时间点会把日志清空

2)循环日志(spdlog::rotating_logger):日志创建成功后,如果写入的日志大小超过限制就会写入到新日志文件中去。不过同时存在的日志总数是有上限的,达到上限后按指定策略淘汰。需要特别注意的是日志更迭的规则是:当日志A存满时,将日志A名称更改为B,再新建一个日志命名为A,依次类推,直到达到上限数字

3)单个日志(spdlog::basic_logger):只有一个日志文件,所有日志都会在该文件中累加

除了3种文件日志外,输出终端(控制台)也比较常用啦

4)输出终端(spdlog::stdout_color):日志打印至终端,不同等级日志颜色不同

Spdlog 日志等级

enum level_enum {

trace= SPDLOG_LEVEL_TRACE 0

debug= SPDLOG_LEVEL_DEBUG 1

info = SPDLOG_LEVEL_INFO 2(默认输出等级)

warn= SPDLOG_LEVEL_WARN 3

err= SPDLOG_LEVEL_ERROR 4

critical= SPDLOG_LEVEL_CRITICAL 5

off = SPDLOG_LEVEL_OFF 6

}

日志级别

控制台日志级别

SPDLOG_DEBUG

SPDLOG_INFO

SPDLOG_WARN

SPDLOG_ERROR

SPDLOG_CRITICAL

旋转日志级别

SPDLOG_INFO_FILE

SPDLOG_WARN_FILE

SPDLOG_ERROR_FILE

SPDLOG_CRITICAL_FILE

Spdlog 异步与同步

同步/异步指日志信息是否直接输出/写入文件,直接写就是同步,稍后写就是异步。spdlog默认的状态就是同步了。

异步状态下,日志会先存入队列,然后由线程从队列中取数据,当队列满的时候会有淘汰策略。如果工作线程中抛出了异常,向队列写入下一条日志时异常会再次抛出,可以在写入队列时捕捉工作者线程的异常,淘汰策略一般两种:

1)阻塞新来的的日志,直到队列有剩余空间(默认处理方式)

2)把新的日志丢掉(需要设定:spdlog::set_async_mode(队列大小,

Spdlog 单线程与多线程

spdlog中提供了单线程和多线程模式,由使用者在对象创建中自己指定。  st:单线程版本,不用加锁,效率高,但不保证线程安全  mt:多线程版本,保证多线程并发情况线程安全,但效率稍低

Spdlog 输出格式:

Pattern说明

输出格式的Pattern中可以有若干 %开头的标记,含义如下表:

标记 说明

%v 实际需要被日志记录的文本,如果文本中有{占位符}会被替换

%t 线程标识符

%P 进程标识符

%n 日志记录器名称

%l 日志级别

%L 日志级别简写

%a 简写的周几,例如Thu

%A 周几,例如Thursday

%b 简写的月份,例如Aug

%B 月份,例如August

%c 日期时间,例如Thu Aug 23 15:35:46 2014

%C 两位年份,例如14

%Y 四位年份,例如2014

%D 或 %x MM/DD/YY格式日期,例如"08/23/14

%m 月份,1-12之间

%d 月份中的第几天,1-31之间

%H 24小时制的小时,0-23之间

%I 12小时制的小时,1-12之间

%M 分钟,0-59

%S 秒,0-59

%e 当前秒内的毫秒,0-999

%f 当前秒内的微秒,0-999999

%F 当前秒内的纳秒, 0-999999999

%p AM或者PM

%r 12小时时间,例如02:55:02 pm

%R 等价于%H:%M,例如23:55

%T 或 %X HH:MM:SS

%z 时区UTC偏移,例如+02:00

%+ 表示默认格式

Spdlog 刷新参数:

刷新方式指日志何时写入文件中,spdlog提供了两种刷新方式:

1)程序正常退出时写入(默认)

2)程序运行中,在指定位置进行写入(实时刷新日志,便于锁定错误所在位置)

要想使用实时刷新日志,spdlog提供了两种方法:

方法一:logger对象->flush_on(设定等级),flush_on是一次性刷新,执行到此时按照设定等级进行日志刷新。

方法二:logger对象->flush_every(周期时间),flush_every是设置刷新周期,定时进行刷新。刷新的级别采取默认了。

参考资料:

https://zhuanlan.zhihu.com/p/337877916

https://blog.csdn.net/xmcy001122/article/details/105864473/?utm_medium=distribute.pc_relevant.none-task-blog-title-2&spm=1001.2101.3001.4242

https://www.cnblogs.com/Braveliu/p/12375556.html

https://www.jianshu.com/p/b0322391d‍a9f

https://www.freesion.com/article/397888765/

https://blog.gmem.cc/spdlog

http://www.360doc.com/content/20/0114/10/65839724_886099666.shtml

https://blog.csdn.net/gls_nuaa/article/details/126738472

https://blog.csdn.net/qq_36583051/article/details/115628620

https://cloud.tencent.com/developer/article/2102109

常见问题—

VS SDK安装:

VS2017报错之“errorMSB8036: 找不到 Windows SDK 版本8.1。请安装所需的版本的 Windows SDK 或...”解决方法

https://blog.csdn.net/weixin_43051346/article/details/122407923

"0xa0"转换为十进制为160,表示汉字的开始。这种错误主要是因为拷贝导致,在程序头或者尾部,可能又空格之类的符号

https://blog.csdn.net/yunken28/article/details/96331082

https://blog.csdn.net/lihaidong1991/article/details/104503187

关键词: 输出终端 输出格式

天天热议:#Spdlog# Spdlog的编译与使用

“文章所涉及内容更多来自网络,在此声明,并感谢知识的贡献者!”CMake—Cmake简介CMake是一个跨平台的编译(Build)工具,可以用简单的语句来描述所2023-01-12

天天即时:美女戴副局长少女照曝光!大学时期清纯可爱,19岁工作后魅力急升

美女戴副局长少女照2023年1月份,扬州美女戴副局长的事迹被传得沸沸扬扬,虽然事情尚未尘埃落定,可是丝毫不妨碍网友们展开对她的讨论。随着事2023-01-12

【环球快播报】2023年台山市春节活动汇总

【台山迎新春文化活动】一、市级“奋进新征程”文艺晚会2023年1月22日(年初一)19:30——21:00台城石化文化广场“曲韵歌盛世”曲艺专场展演2023年12023-01-12

焦点速读:湖北省孝感市规定的产假有多少天?

产假最多休128天,其中国家规定产假98天,地方规定产假30天。2023-01-12

世界滚动:庆阳北750千伏输变电工程取得环评批复

庆阳北750千伏输变电工程取得环评批复,1月4日,庆阳北750千伏输变电工程取得了甘肃省生态环境厅核发的关于本工程环境影响报告书的批复,标志2023-01-12

当前关注:始于球技,忠于人品——致莱奥·梅西

梅西的足球生涯足够传奇生动,在俱乐部从青训到职业梅西可谓年少成名,平步青云,更是在巴萨罗那俱乐部实现了个人荣誉大满贯。然而在阿根廷国2023-01-12

环球微动态丨共建共享停车平台 助力化解城市停车难

2022年12月25日,第三届广州国际智慧物业博览会【前瞻 展望】2022中国(广州)智慧物业管理产业高峰论坛圆满举办。行业领军人物齐聚一堂,共同探2023-01-11

天天讯息:海融科技:公司旗下产品包括混合脂奶油、植脂奶油、稀奶油、植物蛋白饮品、果酱、巧克力、香精香料、冷冻甜点等

同花顺(300033)金融研究中心1月11日讯,有投资者向海融科技(300915)提问,董秘您好,请问贵公司都有哪些产品?都涉及哪些业务?公司回答表2023-01-11

焦点速看:1.38-1.49元/Wh,蒙电综能甘镇100MW风电项目储能系统中标候选人公示

1月8日,内蒙古能源集团蒙电综能甘镇100MW风电项目储能系统设备采购中标人候选人公示,项目规模30MW 60MWh。远景能源有限公司以8340万元的报价2023-01-11

当前快看:尚太科技:公司人造石墨负极材料的原材料主要是石油焦、针状焦,截至目前全部为采购,公司不生产焦类原料

同花顺(300033)金融研究中心1月11日讯,有投资者向尚太科技(001301)提问,公司生产负极负极的原料是自有还是采购公司回答表示,您好,感谢2023-01-11

世界百事通!捣鼓一次智能电视,终于迷失了自我

有一天,你心血来潮,打开久违的电视机,想找点好看的节目消遣。左按右按,一顿操作猛如虎。复杂的入口、琳琅满目的页面、缤纷的收费项目,你2023-01-11

世界快报:德国去年11月工业产出环比微升0.2%

德国联邦统计局9日公布的数据显示,经价格、季节和工作日调整后,2022年11月德国工业产出环比微幅上升0 2%。数据显示,2022年11月德国能源业产2023-01-11

动态:对宠物的句子(精选141句)

对宠物的句子精选63句1 那条小狗一身金黄色的毛,闪闪发亮,像刚刚擦过油似的。2 如果,年华不曾走远,我不愿拥着一池冷寒,以孤独的背影在风2023-01-10

今亮点!隆基绿能: 第五届监事会2023年第一次会议决议公告

隆基绿能:第五届监事会2023年第一次会议决议公告2023-01-10

天天观察:厦门技能提升补贴申请材料

厦门技能提升补贴申请材料:1、身份证或社保卡原件;本人身份证原件(台湾同胞提供台湾居民来往大陆通行证;港澳同胞提供港澳居民来往内地通行2023-01-10

最新资讯:最强组件来袭!晶科能源(688223.SH)全球发布第二代Tiger Neo组件

智通财经APP获悉,2023年1月10日,晶科能源发布全球最高效的太阳能组件产品之一—第二代TigerNeo系列组件。据了解,新一代TigerNeo组件采用了2023-01-10

天天视点!广联达: 关于2020年股票期权与限制性股票激励计划暂缓授予的限制性股票实施第二期解除限售的公告

广联达:关于2020年股票期权与限制性股票激励计划暂缓授予的限制性股票实施第二期解除限售的公告2023-01-10

即时看!大摩:予数码通电讯(00315.HK)“与大市同步”评级 目标价5.5港元

大摩发布研究报告称,予数码通电讯(00315 HK)“与大市同步”评级,相信股价60日内将升,发生机率超过80%,目标价5 5港元。2023-01-10

世界速读:琼海2016年二级工伤赔偿标准怎么算

职工因工致残被鉴定为一级至四级伤残的,保留劳动关系,退出工作岗位,享受以下待遇:(一)从工伤保险基金按伤残等级支付一次性伤残补助金,2023-01-10

今日热门!捷信网贷逾期了13个月会上征信吗?

网贷逾期一般会上征信,有些借贷机构在用户逾期后一天后就会上报给征信机构,而有些借贷机构则是会在几天后上报给征信机构,因为有些借贷机构可2023-01-10

焦点播报:还呗网贷逾期6个月会不会上征信

网贷逾期一般会上征信,有些借贷机构在用户逾期后一天后就会上报给征信机构,而有些借贷机构则是会在几天后上报给征信机构,因为有些借贷机构可2023-01-10

【时快讯】多家银行调整存款利率 年终奖怎么存更划算?

中小银行纷纷调整存款利率每年的岁末年初,伴随着年终奖发放,通常是银行大力“揽储”的黄金时节。近期,包括哈密市商业银行、乌鲁木齐银行、2023-01-09

焦点简讯:(新春见闻)春运首日:中国多地开启“趣暖返乡”

中新社北京1月7日电 1月7日,2023年中国铁路春运正式拉开帷幕。中国各地车站迎来返乡客流,旅客的“归家路”不乏趣味与温暖。当日9时15分,阳2023-01-09

环球今日报丨博实股份(002698):产业链横纵向拓展顺利 打开长期成长天花板

国内智能设备供应商龙头。公司前身是成立于1997年的哈尔滨自动化设备有限责任公司,于2012年首次发行A股成功并在深圳证券交易所上市,是智能设2023-01-09

每日播报!西南航空(LUV.US)预计12月运营中断导致2022年Q4出现净亏损

智通财经APP获悉,西南航空周五在一份监管申报文件中表示,该公司在2022年12月21日到2022年12月31日期间取消了超过1 67万个航班后,由于运营中2023-01-07