重置ostream,C ++

时间:2010-11-25 10:36:28

标签: c++ linux iostream ostream

我有两个不同的ostream,其中一个是cerr,使用相同的streambuffer,我有一些库可能会以某种方式修改cerr,(标志?格式修饰符?)。

cerr.rdbuf(&mystreambuffer);
ostream teststream(&mystreambuffer);

cerr << "This " << " is " << " a " << " test";
teststream << "This " << " is " << " a teststream " << " test";

打印:

This
is
a
test
This is a teststream test

调试mystreambuffer我注意到cerr每mystreambuffer->sync()次操作调用<<,而teststream根本不调用它。
如果我是正确的cerr只是一个标准的ostream,那么,为什么我在冲洗时间看到这种差异?如何将cerr重置为正常的冲洗操作?

编辑:我看到你们正在评论unitbuf并且它在cerr中是默认的,但是如果它是默认的,那么它也不会一步一步写在这里吗?

#include <iostream>
int main(){
    std::cerr << "This " << " is " << " a cerr " << " test\n";
    std::cout << "This " << " is " << " a cout " << " test\n";
}
Cobain /tmp$ ./test 
This  is  a cerr  test
This  is  a cout  test

2 个答案:

答案 0 :(得分:1)

试试std::cerr.unsetf( std::ios_base::unitbuf );。该标志默认为cerr

答案 1 :(得分:1)

ios :: unitbuf标志是cerr设置为默认值的原因。

您需要使用nounitbuf操纵器来修复它。一些较旧的库可能没有它,如果是,那么使用unsetf。

编辑: unitbuf的默认设置取决于实现:)