前后从小白到勉强能够使用spdlog日志库前后就几天时间吧,到现在有时间好好静下来反思一下学习步骤,想想哪一步还能再继续改进
刚入手时,看到的代码都是以往的学长们动过的,代码阅读难度大,基本上是缺失太多的东西了,后面才发现可以从GitHub上面直接扒拉源码下来。
首先讲讲应用spdlog的基本配置(非常简单且方便)
首先在Github上面找到spdlog的项目,别人都帮你写好了日志库了,其实后面的工作就是读懂代码和使用代码就好了,
其次,扒拉源码到自己电脑上面去
下好了后注意,找到include文件夹,里面是c++的头文件库,关键的东西都在里面,把include下一级的spdlog文件复制粘贴到,自己电脑的c++编译路径中include文件夹的下面去(这要求大家一定要知道自己c++环境的配置,要知道自己的编译路径在哪里)
例如,这是我的路径,放到配置好的编译路径下
这样配置好了后,就可以很方便愉快的进行我们的代码构架了,你就可以直接调用
#include<spdlog/spdlog.h> 等一系列的库了,超级方便,简单易懂的操作。
后面就是代码研读部分,作为一个萌新刚入Github,我不知道Github下面就是代码使用模板,在如何使用,如何调试spdlog上面花费了大量的时间,后面从各种途径如CSDN呀,知乎呀等渠道去了解如何使用,功能是什么,语法是什么,兜兜转转了一大圈,才发现,看那些有啥用啊?基本上都是别人消化过后的东西了,还不如自己去看源码,看官方注释,
虽然本人英语不是很好,但是像下面这种的还是读的懂的,语法结构,使用方法我就不做特别描述,如果只是简单的学习使用spdlog的话,看完官方Usage sample就够了,如果还想要自己搞出更多功能,建议直接去读spdlog.h里面的函数定义,再进入函数去看如何实现,自己写一个玩玩也无所谓。
下面是自己乱搞出来的东西,由于不是很会用c++的命名空间这里面用的是 using namespace std
头文件引用,毫无新意
在这里面简单写了一个获取时间的函数,把logs文件建立的路径都写好了
同时给每天文件上限和单个文件空间上限也写好了
写了一个死循环,让他在远程服务器上面跑,看看跑一天大概就干多少叭,总体来说没什么大问题,和预期的一模一样,但是要注意,后面一定要加上
spdlog::drop_all();
这句话,能够关闭当前的file_logger指针,logger使用完但是程序没有跑完,如果不调用drop函数去释放logger对象,则在程序中就无法再次建立同名的logger,所以你的程序可能就一直返回异常啊之类的东西。
后面就是实现上面的函数了,没什么东西,可以理解理解,知道是个什么样的用途就好了,没必要去搞懂,这个是啥是啥的。
总的来说,看懂了官方给的文档,我们就可以改造了,拿别人写好的轮子,我们就可以跑了.
收获还是很大的,起码对与学习方法有了一个比较新的认识。