我有两个不同的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
答案 0 :(得分:1)
试试std::cerr.unsetf( std::ios_base::unitbuf );
。该标志默认为cerr
。
答案 1 :(得分:1)
ios :: unitbuf标志是cerr设置为默认值的原因。
您需要使用nounitbuf操纵器来修复它。一些较旧的库可能没有它,如果是,那么使用unsetf。
编辑: unitbuf的默认设置取决于实现:)