每次使用cin和cerr时,都会导致cout的缓冲区被刷新,什么原理呢?
因为cin和cerr都被关联到了cout,读cin或者写cerr都会导致输出缓冲区被刷新.
这其中的关联函数是tie,有2个函数模型
std::basic_ostream* tie() const;
/*
* 如果本对象已经关联一个输出流,则返回指向这个输出流的指针
* 如果本对象没有关联任何输出流,则返回空指针
*/
std::basic_ostream* tie( std::basic_ostream* str );
/*
* 形参接受一个指向ostream的指针,将本对象关联到此ostream
* 函数返回值是上一个绑定的输出流指针,如果本对象没有关联任何输出流,则返回空指针
*/
详细解释
*cin.tie() << "hello world" << endl;
//我们知道系统已经把cin关联到了cout上,每次执行cin,都会导致输出缓冲区刷新
//cin.tie(),返回的就是他绑定的输出流cout的指针,那么*cin.tie()就是cout
ostream* old_tie = cin.tie(nullptr);
//cin被关联到了nullptr上,也就是不再和任何流关联,同时返回值是上一个输出流指针,也就是指向cout的指针
cin.tie(&cerr)
//每次从cin中提取数据时,都会先刷新cerr,而不再是cout
cin.tie(old_tie)
//重建cin和cout间的正常关联
/****重点注意******/
每个流同时最多关联一个流,但是多个可以同时关联到同一个ostream
这句话的是像cin,cerr每次都只能关联一个流,但是都可以关联到cout上
int main ()
{
ofstream ofs("1.txt");
cin.tie (&ofs); //将cin关联到了ofs文件输出流上了
*cin.tie() << "There will be some text:"; //此时*cin.tie()就等价ofs
//如果我们将cin.tie (&ofs);这句话注释掉,那么*cin.tie()就等价cout
ofs.close();
return 0;
}
watch -n 0.1 'cat 1.txt'
每隔0.1s 执行一遍cat 1.txt