c++ 日志模块 标准库封装

log.h

    #ifndef LOG_H
    #define LOG_H
    #include <vector>
    #include <iostream>
    #include <string>
    
    struct LogFormat {
        std::vector<std::string> perfixs;
        LogFormat(const std::vector<std::string> &perfixs = {}) : perfixs(perfixs) {}
        std::string perfixsString(){
            std::string perfixsString;
            for (auto &&one : perfixs) {
                perfixsString += "[" + one + "]";
            }
            return perfixsString;
        }
    };

    struct Stderr : LogFormat {
        Stderr(const std::vector<std::string> &perfixs = {}) : LogFormat(perfixs)
        { std::cerr << perfixsString(); }
        ~Stderr() {std::cerr << std::endl;}
        template<class T> Stderr& operator << (const T &t) {
             std::cerr << t << " ";
            return *this;
        }
    };

    struct Stdout : LogFormat {
        Stdout(const std::vector<std::string> &perfixs = {}) : LogFormat(perfixs)
        { std::cout << perfixsString(); }
        ~Stdout() {std::cout << std::endl;}
        template<class T> Stdout& operator << (const T &t) {
            std::cout << t << " ";
            return *this;
        }
    };
    
#define LogErr Stderr({__FILE__, std::to_string(__LINE__), "Error"})
#define LogOut Stdout({__FILE__, std::to_string(__LINE__), "Output"})

#endif // LOG_H

std输出格式的默认兼容, 列表中可添加其他前缀,如下:

 #define LogOut Stdout({__DATA__, __FILE__, std::to_string(__LINE__), "Output"})

使用方法:

   LogErr << 10 << "string";
   LogOut << 10 << "string";

输出格式:

[__DATA__][__FILE__][__LINE__][Output] 10 string
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值