代码拉取完成,页面将自动刷新
#pragma once
#include <iostream>
#include <time.h>
#include <stdarg.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
//是unix标准中通用的头文件,其中包含的相关函数有 open,unlink,fclose等!
#include <unistd.h>
#include <stdlib.h>
#define SIZE 1024
#define Info 0 //定义程序不同的退出状态(level)
#define Debug 1
#define Warning 2
#define Error 3
#define Fatal 4
#define Screen 1 //定义三种日志文件
#define Onefile 2
#define Classfile 3
#define LogFile "log.txt"
class Log
{
public:
Log()
{
printMethod = Screen; //此处设置成默认在屏幕中输出日志文件
path = "./log/";
}
void Enable(int method)
{
printMethod = method;
}
std::string levelToString(int level)
{
switch (level)
{
case Info:
return "Info";
case Debug:
return "Debug";
case Warning:
return "Warning";
case Error:
return "Error";
case Fatal:
return "Fatal";
default:
return "None";
}
}
//##############按具体情况打印日志文件(3种中的1种),打印前需知道日志的退出状态(level)等信息
void printLog(int level, const std::string &logtxt)
{
switch (printMethod)
{
case Screen: //屏幕中输出
std::cout << logtxt << std::endl;
break;
case Onefile: //输出成一个叫"log.txt"的文件
printOneFile(LogFile, logtxt);
break;
case Classfile: //输出成一个类文件(最后还是调用 printOneFile再输出)
printClassFile(level, logtxt);
break;
default:
break;
}
}
void printOneFile(const std::string &logname, const std::string &logtxt)
{
std::string _logname = path + logname;
int fd = open(_logname.c_str(), O_WRONLY | O_CREAT | O_APPEND, 0666); // "log.txt"
if (fd < 0)
return;
write(fd, logtxt.c_str(), logtxt.size());
close(fd);
}
void printClassFile(int level, const std::string &logtxt)
{
std::string filename = LogFile;
filename += ".";
filename += levelToString(level); // "log.txt.Debug/Warning/Fatal"
printOneFile(filename, logtxt);
}
~Log()
{}
//###########运算符重载,仿函数,该函数得出日志的时间信息形成打印日志所需的logtxt
void operator()(int level, const char *format, ...)
{
//##########1.###################//得到并处理日志的时间
time_t t = time(nullptr);
//localtime是 把从1970-1-1零点零分到当前时间系统所偏移的秒数时间转换为本地时间,
struct tm *ctime = localtime(&t);
char leftbuffer[SIZE];
//输出日志的年-月-日-时-分-秒
snprintf(leftbuffer, sizeof(leftbuffer), "[%s][%d-%d-%d %d:%d:%d]", levelToString(level).c_str(),
ctime->tm_year + 1900, ctime->tm_mon + 1, ctime->tm_mday,
ctime->tm_hour, ctime->tm_min, ctime->tm_sec);
//##########2.###################//对可变参数的处理,因为日志文件中的信息数量可变
//va_list一个指向变长参数列表的指针,用于获取不确定个数的参数
va_list s;
//va_start一个宏定义,用于在使用可变参数函数时获取可变参数的起始地址。
//va_start的作用是初始化一个va_list类型的变量,使其指向可变参数列表的第一个参数
va_start(s, format);
char rightbuffer[SIZE];
//C语言库函数之一,属于可变参数。用于向字符串中打印数据、数据格式用户自定义
vsnprintf(rightbuffer, sizeof(rightbuffer), format, s);
//va_end一个宏,用于清理va_list变量,并使其不再指向任何有效的内存位置。
//它在可变参数函数的末尾使用,以结束可变参数的处理
va_end(s);
//##########3.###################//将上述得且到处理过的信息输入日志文件
// 格式:默认部分+自定义部分
char logtxt[SIZE * 2];
//将可变参数 “leftbuffer, rightbuffer” 按照"%s %s"的格式格式化为字符串,然后再将其拷贝至logtxt中
snprintf(logtxt, sizeof(logtxt), "%s %s", leftbuffer, rightbuffer);
//##########4.###################//调用打印日志文件函数
printLog(level, logtxt);
}
private:
int printMethod;
std::string path;
};
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。