o字符串流在插入输出后为空

ostringstream is empty after inserting output to it

本文关键字:输出 插入 字符串      更新时间:2023-10-16

我有一个奇怪的问题,即使我在其中插入输出,ostringstream 也是空的。 这是我的代码:

//logger.h
#include <string>
#include <iostream>
#include <sstream>
using std::string;

class BasicLogger {
public:
BasicLogger(const string name);
BasicLogger(const BasicLogger& basicLogger);
~BasicLogger();
template<class T>
BasicLogger& operator<<(const T &msg){
std::cout << "msg is: " << msg << std::endl;
mBuf << msg;
std::cout << "mBuf is: " << mBuf.str() << std::endl;
return *this;
}

private:
string mName;
std::ostringstream mBuf;
};

class Logger {
public:
Logger();
~Logger();
BasicLogger info();
BasicLogger error();
private:
BasicLogger mInfoLogger;
BasicLogger mErrorLogger;
};

//logger.cpp
#include "logger.h"
BasicLogger::BasicLogger(const string name):
mName(name) { }
BasicLogger::BasicLogger(const BasicLogger& otherLogger) {
this->mName = otherLogger.mName;
this->mBuf << otherLogger.mBuf.rdbuf();
}
BasicLogger::~BasicLogger() { }
Logger::Logger(): 
mInfoLogger("[INFO]"),
mErrorLogger("[ERROR]") {}
Logger::~Logger() {};
BasicLogger Logger::info() {
return mInfoLogger;
}
BasicLogger Logger::error() {
return mErrorLogger;
}

//main.cpp
#include "logger.h"
int main() {
Logger logger;
logger.info() << "Hellooo";
}

输出为

msg is: Hellooo
mBuf is: 

虽然@BoPersson已经为您提供了解决方案,但我想解释一下这里发生了什么,以及为什么您的输出是空的,即使您在显示其内容之前添加到行上的ostringstream

我认为当您尝试按值返回mInfoLogger时,编译器抱怨无法返回它,因为复制构造函数被删除。由于您拥有的成员而删除ostringstream原因是不可复制的。

因此,您提供了自定义复制构造函数并尝试以这种方式复制流:

this->mBuf << otherLogger.mBuf.rdbuf();

只有这不会复制任何内容,因为您的rdbuf为空,而是failbit

故障位

basic_ostream::运算符的 streambuf 重载<<如果函数 不插入任何字符。 http://en.cppreference.com/w/cpp/io/ios_base/iostate

如果您要像这样检查邮件插入:

if (!(mBuf << msg))
std::cout << "Not Inserted" << std::endl;

您将看到打印Not Inserted消息。有很多方法可以使其打印所需的消息。例如,确保您的rdbuf缓冲区不为空,或者在重用mBuf之前重置failbit,类似于mBuf.clear();或简单地将引用返回到mInfoLogger(和mErrorLogger(。然后你可以安全地摆脱你的复制构造函数。