#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://bianchenghao.cn/hz/148564.html