如何像std C++流一样使用我的日志类?

new*_*gre 13 c++ logging stream

我有一个工作的记录器类,它将一些文本输出到richtextbox(Win32,C++).问题是,我总是这样使用它:

stringstream ss;  
ss << someInt << someString;  
debugLogger.log(ss.str());
Run Code Online (Sandbox Code Playgroud)

相反,像流一样使用它会更方便:

debugLogger << someInt << someString;
Run Code Online (Sandbox Code Playgroud)

有没有比将内容转发到内部stringstream实例更好的方法?如果这样做,我什么时候需要冲洗?

Kon*_*lph 33

您需要operator <<为您的班级适当地实施.一般模式如下:

template <typename T>
logger& operator <<(logger& log, T const& value) {
    log.your_stringstream << value;
    return log;
}
Run Code Online (Sandbox Code Playgroud)

请注意,这会处理(非const)引用,因为操作会修改您的记录器.另请注意,您需要返回log参数才能使链接起作用:

log << 1 << 2 << endl;
// is the same as:
((log << 1) << 2) << endl;
Run Code Online (Sandbox Code Playgroud)

如果最内层操作没有返回当前log实例,则所有其他操作将在编译时失败(错误的方法签名)或在运行时被吞下.

  • 或者添加模仿endl/ends的自己的操纵符类型,并使用<<运算符的重载来检测它. (2认同)

Luc*_*tte 14

重载插入操作符<<不是要走的路.您必须为所有endl或任何其他用户定义的函数添加重载.

要做的就是定义自己的streambuf,并将其绑定到流中.然后,您只需使用流.

以下是一些简单的例子: