2
我想把istream变成ostream...我试过这样做:
std::cout << my_istream.rdbuf() << '\n';
但当istream碰巧是空的,它会触发failbit.的.ostream(比照operator<<,重载9),这会导致'\n'以及后来没有印出来的任何东西。
为什么会触发failbit(这样做的理由是什么?)还有其他方法可以打印不认为空流是错误的流吗?
为了避免这个问题,我可以这样做:
char c;
while(my_stream.get(c)) std::cout.put(c);
不过,如果有人能指导我委员会决定触发failbit如果缓冲区为空吗
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
在C++中,iostream库的设计遵循了状态机的模式,其中failbit
是一个表示流错误状态的标志位。当你尝试从一个空的istream
读取数据时,它会设置failbit
来表明读取操作未成功完成。这是设计上的选择,旨在帮助程序员识别和处理潜在的读取失败情况。
具体到你的问题,当你直接将一个空的istream
(比如没有可读数据的文件或字符串流)与ostream
进行连接以尝试输出时,实际上是在尝试执行一次隐式的读取操作(通过提取运算符>>
),这自然会导致读取失败,从而设置了failbit
。
关于为何委员会决定这样设计,主要是为了提供一种机制,使得程序能够自动检测并响应输入流中的错误或异常情况,而无需程序员显式检查每次读取是否成功。这种设计鼓励编写更健壮、能有效处理错误的代码。
如果你想要打印流内容而不关心它是否为空,同时避免因为空流而触发failbit
,可以采用你已经提到的方法:手动控制读取和写入过程。即,使用循环和条件检查来安全地从istream
读取数据,并逐一写入到ostream
中。这样做给了你更多的控制权,可以自定义错误处理逻辑,例如忽略空流而不是视为错误。
另一种方法是,在进行读取之前,先检查流的状态,如果流是好的(即没有设置任何错误位),则继续读取操作。示例代码如下:
if (my_stream) {
char c;
while(my_stream.get(c)) {
std::cout.put(c);
}
} else {
// 处理流不好的情况,比如提示信息或者采取其他措施
std::cerr << "Stream is not good for reading." << std::endl;
}
这样的设计允许你更加灵活地管理流的状态和错误处理逻辑。