zoukankan      html  css  js  c++  java
  • c++封装简单日志操作

    logger.h

    /**
     * logger.h
     * @brief 简易日志模块
     */
    #ifndef __LOGGER_H__
    #define __LOGGER_H__
    
    #include <iostream>
    #include <iomanip>
    #include <fstream>
    #include <string>
    #include <cstdlib>
    #include <stdint.h>
    
    typedef enum log_rank{
            INFO = 0,
            WARNING,
            ERROR,
            FATAL,
    } log_rank_t;
    
    void initLogger(const std::string &info_filename, const std::string &warn_filename,
                                    const std::string &error_filename);
    
    class Logger{
            friend void initLogger(const std::string &info_filename, const std::string &warn_filename,
                                    const std::string &error_filename);
    public:
            Logger(log_rank_t log_rank):m_log_rank(log_rank){};
            ~Logger();
            static std::ostream &start(log_rank_t log_rank, const int line, const std::string &fun);
    
    private:
            static std::ostream &getStream(log_rank_t log_rank);
    
            static std::ofstream m_info_file;
            static std::ofstream m_warn_file;
            static std::ofstream m_error_file;
            log_rank_t m_log_rank;
    };
    
    #define LOG(log_rank) 
            Logger(log_rank).start(log_rank, __LINE__, __FUNCTION__)
    
    #endif
    #include <cstdlib>
    #include <ctime>
    #include "logger.h"
    
    std::ofstream Logger::m_info_file;
    std::ofstream Logger::m_warn_file;
    std::ofstream Logger::m_error_file;
    
    void initLogger(const std::string &info_filename, const std::string &warn_filename, 
                                    const std::string &error_filename){
            Logger::m_info_file.open(info_filename.c_str(), std::ofstream::app);
            Logger::m_warn_file.open(warn_filename.c_str(), std::ofstream::app);
            Logger::m_error_file.open(error_filename.c_str(), std::ofstream::app);
    }
    
    std::ostream &Logger::getStream(log_rank_t log_rank){
            if(log_rank == INFO){
                    return m_info_file.is_open() ? m_info_file : std::cout;
            }
            if(log_rank == WARNING){
                    return m_warn_file.is_open() ? m_warn_file : std::cout;
            }
            if(log_rank == ERROR){
                    return m_error_file.is_open() ? m_error_file : std::cout;
            }
    }
    
    std::ostream &Logger::start(log_rank_t log_rank, const int line, const std::string &fun){
            time_t tm;
            time(&tm);
            char time_string[128];
            strftime(time_string, sizeof(time_string),"[%Y.%m.%d %X] ", localtime(&tm));
            return getStream(log_rank) << time_string 
                                                               << "function[" << fun <<"] " 
                                                               << "line[" << line <<"] " 
                                                               << std::flush;
    }
    
    Logger::~Logger(){
            getStream(m_log_rank) << std::endl << std::flush;
            if(m_log_rank == FATAL){
                    m_info_file.close();
                    m_warn_file.close();
                    m_error_file.close();
                    abort();
            }
    }

    测试文件

    #include <iostream>
    #include "logger.h"
    
    int main(){
            initLogger("log/info.log", "log/warning.log", "log/error.log");
            LOG(INFO) << "info " << "test";
            LOG(INFO) << "info " << "test";
            LOG(WARNING) << "warning " << "test";
            LOG(WARNING) << "warning " << "test";
            LOG(ERROR) << "error " << "test";
            LOG(ERROR) << "error " << "test";
    }
  • 相关阅读:
    IMWebConf 2017 官网彩蛋解谜
    解决SVG animation 在IE中不起作用
    百度大搜和度秘面经
    浅谈JavaScript原型与原型链
    听说2017你想写前端?
    如何制作icon-font小图标
    HTML5 CSS3 诱人的实例 :模仿优酷视频截图功能
    javaweb action无法跳转、表单无法跳转的解决方法
    hadoop备战:yarn框架的搭建(mapreduce2)
    liferay 指定默认首页
  • 原文地址:https://www.cnblogs.com/bai-jimmy/p/6856336.html
Copyright © 2011-2022 走看看