c++ - 以类似 cout 的符号在 C++ 中管理日志流

标签 c++ logging printing operator-overloading

我有一个 C++ 类,用于为我的应用程序编写日志文件。我已经构建了这个类并且它可以工作,它是这样的:

class Logger {
   std::string _filename;
public: 
   void print(std::string tobeprinted);
}

嗯,很直观,为了在日志文件中打印一行,对于 Logger 对象,只需要执行以下操作:

Logger mylogger("myfile.log");
mylogger.print(std::string("This is a log line"));

嗯。使用方法方法与使用像 << 这样更好的模式是不同的。 我想执行以下操作:

Logger mylogger("myfile.log");
mylogger << "This is a log line";

就是这样。我想我必须重载 << 运算符......但是使用这个签名(经典签名)重载:

ostream& operator<<(ostream& output, const MyObj& o);

但是我没有ostream... 那么,我应该怎么做呢?

Logger& operator<<(Logger& output, const std::string& o);

这是正确的方法吗? 谢谢

最佳答案

class Log
{
public:

    enum Level { Debug, Error, Info };

    static ostream& GetStream() { return cout; }
    static bool IsLevelActive(Level l) { return true; }
};

#ifndef NO_LOG
#define LOG_ERROR(M)   do { if (Log::IsLevelActive(Log::Error))   (Log::GetStream() << "ERR: " << M << "\n"); } while (false)
#define LOG_INFO(M)    do { if (Log::IsLevelActive(Log::Info))    (Log::GetStream() << "INF: " << M << "\n"); } while (false)
#define LOG_WARNING(M) do { if (Log::IsLevelActive(Log::Warning)) (Log::GetStream() << "WRN: " << M << "\n"); } while (false)
#else
#define LOG_ERROR(M)
#define LOG_INFO(M)
#define LOG_WARNING(M)
#endif

struct MyObject {
    int a, b;
};

ostream& operator<<(ostream& ostr, const MyObject& obj) {
    ostr << "(a=" << obj.a << ", b=" << obj.b << ")";
    return ostr;
}

void test() {
    int v1 = 42;
    int v2 = 43;
    LOG_INFO("value1=" << v1 << ", value2=" << v2);

    MyObject o = {1, 2};
    LOG_INFO("obj=" << o);
}

关于c++ - 以类似 cout 的符号在 C++ 中管理日志流,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4563094/

相关文章:

c++ - 为什么在声明 move 操作时删除复制操作?

c++ - 如何一次从文本文件中读取一个字符

java - Log4j2:如何指定要保留的最大副本数?

c++:如何在没有回车的情况下打印新行

php - 编写 PHP 代码来打印以下数字模式

C++:将 vector<char> 转换为 UTF-8 字符串,以便我可以通过 Websocket 发送

c++ - 多次调用 `std::future::then` 的行为是什么?

logging - IntelliJ IDEA 运行控制台日志中的 "Clear All"快捷方式

.net - Diagnostics.Trace 跨多个域

css - @media 打印不适用于显示 :none