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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • idea 2022 Mac 激活码【中文破解版】

    (idea 2022 Mac 激活码)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html4KDDGND3CI-eyJsaWN…

    2022年4月1日
    463
  • 六大算法之动态规划_leetcode迷宫最短路径

    六大算法之动态规划_leetcode迷宫最短路径在两条独立的水平线上按给定的顺序写下 nums1 和 nums2 中的整数。现在,可以绘制一些连接两个数字 nums1[i] 和 nums2[j] 的直线,这些直线需要同时满足满足:nums1[i] == nums2[j]且绘制的直线不与任何其他连线(非水平线)相交。请注意,连线即使在端点也不能相交:每个数字只能属于一条连线。以这种方法绘制线条,并返回可以绘制的最大连线数。示例 1:输入:nums1 = [1,4,2], nums2 = [1,2,4]输出:2解释:可以画出两条不交叉的

    2022年8月9日
    3
  • Redis为什么这么快?Redis的线程模型与Redis多线程

    Redis为什么这么快?Redis的线程模型与Redis多线程

    2021年10月5日
    30
  • java中beanutils_java bean

    java中beanutils_java beanBeanUtils<!–原型设计模式:复制属性–> Maven包<dependency><groupId>commons-beanutils</groupId><artifactId>commons-beanutils</artifactId><version>1.9.3</version>

    2022年9月5日
    2
  • webpack配置文件_pack luggage

    webpack配置文件_pack luggage前言上一篇文章我们使用webpack打包成功了,但是每次都要自己手动输入打包的文件地址和打包到哪里去的地址,非常麻烦,所以这里介绍使用配置文件进行打包webpack.config.js首先我们创

    2022年8月7日
    5
  • JRTPLIB 3.9.1文档翻译

    JRTPLIB 3.9.1文档翻译MainPageJRTPLIBAuthor:      JoriLiesenborgs      DevelopedattheTheExpertiseCentreforDigitalMedia(EDM),aresearchinstituteoftheHasseltUniversityAcknowledg

    2022年7月28日
    1

发表回复

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

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