spdlog 个人封装,欢迎使用,共同探讨[通俗易懂]

spdlog 个人封装,欢迎使用,共同探讨[通俗易懂]#ifndef_MY_LOG_HPP_#define_MY_LOG_HPP_#include”spdlog/spdlog.h”#include”spdlog/sinks/basic_file_sink.h”//supportforbasicfilelogging#include”spdlog/sinks/rotating_file_sink.h”//suppo…

大家好,又见面了,我是你们的朋友全栈君。

#ifndef _MY_LOG_HPP_
#define _MY_LOG_HPP_

#include “spdlog/spdlog.h”
#include “spdlog/sinks/basic_file_sink.h” // support for basic file logging
#include “spdlog/sinks/rotating_file_sink.h” // support for rotating file logging
#include “spdlog/sinks/stdout_sinks.h”
#include “spdlog/sinks/stdout_color_sinks.h” // or “../stdout_sinks.h” if no colors needed
#include “spdlog/sinks/daily_file_sink.h”

class MyLog
{

public:
    static MyLog& GetInstance();
protected:
    MyLog();
    ~MyLog();
private:
    MyLog(const MyLog& rhs) {}
    MyLog& operator = (const MyLog& rhs) {}
public:
    /*
    trace = SPDLOG_LEVEL_TRACE,
    debug = SPDLOG_LEVEL_DEBUG,
    info = SPDLOG_LEVEL_INFO,
    warn = SPDLOG_LEVEL_WARN,
    err = SPDLOG_LEVEL_ERROR,
    critical = SPDLOG_LEVEL_CRITICAL,
    off = SPDLOG_LEVEL_OFF,
    */
    bool InitLogObject(int consolelevel=0, const int filelevel=0, int maxsize=1000, int backIndex=10,int isDay=1);
    auto& GetConsoleObject();
    auto& GetFileObject();

public:
    int m_isDay;
};
MyLog::MyLog()
{

}
MyLog::~MyLog()
{

    std::cout << “析构了” << std::endl;
}
MyLog& MyLog::GetInstance()
{

    static MyLog instance;
    return instance;
}
auto& MyLog::GetConsoleObject()
{

    return spdlog::get(“console”);
}
auto& MyLog::GetFileObject()
{

    if (m_isDay==1)
    {

        return spdlog::get(“daily_logger”);
    }
    return spdlog::get(“file_logger”);
}

bool MyLog::InitLogObject(int consolelevel, int filelevel,int maxsize,int backIndex,int isDay)
{

    try
    {

        m_isDay = isDay;
        auto console = spdlog::stdout_logger_mt(“console”);

        switch (consolelevel)
        {

        case 0:console->set_level(spdlog::level::trace); break;
        case 1:console->set_level(spdlog::level::debug); break;
        case 2:console->set_level(spdlog::level::info); break;
        case 3:console->set_level(spdlog::level::warn); break;
        case 4:console->set_level(spdlog::level::err); break;
        case 5:console->set_level(spdlog::level::critical); break;
        case 6:console->set_level(spdlog::level::off); break;
        default:
            console->set_level(spdlog::level::trace);
            break;
        }
        // 单位M 即:maxsize M
        auto file_logger = spdlog::rotating_logger_mt(“file_logger”, “logs/rotat.log”, 1024 * 1024 * maxsize, backIndex);
        auto daily_logger = spdlog::daily_logger_mt(“daily_logger”, “logs/daily.log”, 23, 59);
        switch (filelevel)
        {

        case 0:
        {

            file_logger->set_level(spdlog::level::trace); 
            daily_logger->set_level(spdlog::level::trace);
            break;
        }
        case 1:
        {

            file_logger->set_level(spdlog::level::debug);
            daily_logger->set_level(spdlog::level::debug);
            break;
        }
        case 2:
        {

            file_logger->set_level(spdlog::level::info);
            daily_logger->set_level(spdlog::level::info);
            break;
        }
        case 3:
        {

            file_logger->set_level(spdlog::level::warn);
            daily_logger->set_level(spdlog::level::warn);
            break;
        }
        case 4:
        {

            file_logger->set_level(spdlog::level::err);
            daily_logger->set_level(spdlog::level::err);
            break;
        }
        case 5:
        {

            file_logger->set_level(spdlog::level::critical);
            daily_logger->set_level(spdlog::level::critical);
            break;
        }
        case 6:
        {

            file_logger->set_level(spdlog::level::off);
            daily_logger->set_level(spdlog::level::off);
            break;
        }
        default:
        {

            file_logger->set_level(spdlog::level::trace);
            daily_logger->set_level(spdlog::level::trace);
            break;
        }
        }

        return true;
    
    }
    catch (const spdlog::spdlog_ex& ex)
    {

        std::cout << “Log initialization failed: ” << ex.what() << std::endl;
    }
    return true;
}
#endif // !_MY_LOG_HPP_

//调用代码片段

MyLog::GetInstance().InitLogObject();

…….

std::stringstream ss;
ss << __FILE__ << “:” << __FUNCTION__ << “:” << __LINE__ << “:”;
ss<< std::this_thread::get_id();
MyLog::GetInstance().GetFileObject()->info(“日志:{},{}”, “测试文件”, ss.str().data());

MyLog::GetInstance().GetConsoleObject()->info(“日志:{},{}”, “测试控制台”, ss.str().data());

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/152321.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 【11】进大厂必须掌握的面试题-持续集成面试

    Q1。持续集成是什么意思? 我将建议您通过对持续集成(CI)进行小的定义来开始此答案。这是一种开发实践,要求开发人员每天多次将代码集成到共享存储库中。然后,每个签入均由自动构建进行…

    2020年10月20日
    323
  • 1M 等于多少字节

    1M 等于多少字节1M=1024k=1048576字节算法是:8bit(位)=1Byte(字节)1024Byte(字节)=1KB1024KB=1MB1024MB=1GB1024GB=1TB一个汉字要占用2个字节如果换算成中文汉字那么就是1M=524288个汉字

    2022年5月9日
    91
  • Java案例:实现九九乘法表「建议收藏」

    Java案例:实现九九乘法表「建议收藏」Java案例:实现九九乘法表前言本篇文章主要讲述并实现Java实现九九乘法表。一、九九乘法表?九九乘法表就是咱们小学时期最开始接触乘法运算时,数字10以内,以及结果100以内的乘法口诀。二、解题思路因为涉及到行与列,而且均有1~9这样的循环出现,因此首先想到的就是for循环,而且要出现两个其次,因为九九乘法表每一行的等式左边的因数为等式的列,右边的因数为等式的行,同一行,右边的因数不变,所以for循环有嵌套关系又因为左边的因数永远小于等于右边的因数,所以嵌套的for循环条件一定为

    2022年7月15日
    26
  • python模块之psutil详解

    python模块之psutil详解python模块之psutil详解一、psutil模块:1.psutil是一个跨平台库(http://pythonhosted.org/psutil/)能够轻松实现获取系统运行的进程和系统利用率(包括CPU、内存、磁盘、网络等)信息。它主要用来做系统监控,性能分析,进程管理。它实现了同等命令行工具提供的功能,如ps、top、lsof、netstat、ifconfig、who、df、kill…

    2022年6月12日
    34
  • Java酒店管理系统_java酒店管理系统报告

    Java酒店管理系统_java酒店管理系统报告基于jsp+servlet+pojo+mysql实现一个javaee/javaweb的小型酒店管理系统,该项目可用各类java课程设计大作业中,小型酒店管理系统的系统架构分为前后台两部分,最终实现在线上进行小型酒店管理系统各项功能,实现了诸如用户管理,登录注册,权限管理等功能,并实现对各类小型酒店管理系统相关的实体进行管理。该小型酒店管理系统为一个采用mvc设计模式进行开发B/S架构项…

    2022年9月24日
    1
  • bool 函数用法「建议收藏」

    bool 函数用法「建议收藏」 BOOL是布尔型变量,也就是逻辑型变量的定义符,类似于float、double等,只不过float定义浮点型,double定义双精度浮点型。在objective-c中提供了相似的类型BOOL,它具有YES值和NO值。布尔型变量的值只有真(true)和假(false),可用于逻辑表达式,也就是“或”“与”“非”之类的逻辑运算和大于小于之类的关系运算,逻辑表达式运算结果为真或为假。(百科) …

    2022年4月28日
    111

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号