| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 | #include "stdafx.h"# include "log_sys.h"#include "minwinbase.h"string currTime() {    // 获取当前时间,并规范表示    char tmp[64];    time_t ptime;    time(&ptime);  // time_t time (time_t* timer);    strftime(tmp, sizeof(tmp), "%Y-%m-%d %H:%M:%S, ", localtime(&ptime));    //SYSTEMTIME st;    //GetLocalTime(&st);    //char tmp[64] = { 0 };    //sprintf_s(tmp, "[%04d %02d %02d] [%02d:%02d:%02d.%3d]", st.wYear, st.wMonth, st.wDay, st.wHour, st.wMinute, st.wSecond, st.wMilliseconds);    //return tmp;}Logger::Logger(){    // 默认构造函数    this->target = terminal;    this->level = debug;    cout << "[WELCOME] " << __FILE__ << " " << currTime() << " : " << "=== Start logging ===" << endl;}Logger::Logger(log_target target, log_level level, string path){        this->target = target;        this->path = path;        this->level = level;        string tmp = "";  // 双引号下的常量不能直接相加,所以用一个string类型做转换        string welcome_dialog = tmp + "[Welcome] " + __FILE__ + " " + currTime() + " : " + "=== Start logging ===\n";        if (target != terminal){            this->outfile.open(path, ios::out | ios::app);   // 打开输出文件            this->outfile << welcome_dialog;        }        if (target != file){            // 如果日志对象不是仅文件            cout << welcome_dialog;        }    }void Logger::output(string text, log_level act_level){    string prefix;    if(act_level == debug) prefix = "[DEBUG]   ";    else if(act_level == info) prefix = "[INFO]    ";    else if(act_level == warning) prefix = "[WARNING] ";    else if(act_level == error) prefix = "[ERROR]   ";    else prefix = "";    prefix += __FILE__;    prefix += " ";    string output_content = prefix + currTime() + " : " + text + "\n";    if(this->level <= act_level && this->target != file){        // 当前等级设定的等级才会显示在终端,且不能是只文件模式        cout << output_content;    }    if(this->target != terminal)        outfile << output_content;}void Logger::DEBUG(string text){    this->output(text, debug);}void Logger::INFO(string text){    this->output(text, info);}void Logger::WARNING(string text){    this->output(text, warning);}//void Logger::ERROR(string text){//    this->output(text, error);//}void logger_test(){    Logger logger(Logger::file_and_terminal, Logger::debug, "result.log");    logger.DEBUG("What happend?");    logger.INFO("This is good.");    logger.WARNING("Yes...");    //logger.ERROR("IO Error!");}
 |