具体是:
C++为了让cin cout和scanf printf 同时使用时不产生混乱,所以c++用一个缓冲区来同步c的标准流,而std::ios::sync_with_stdio(false)可以关闭这一个同步,让cin和cout不经过缓冲区;
tie()函数是把两个stream绑定到一起,flush()是把缓冲区的数据输出到文件,而cin和cout是默认绑定在一起的,
每次使用都会调用flush(), 而cin.tie(nullptr)可以解除这个绑定;
cin和cout默认绑定在一起,是为了防止cin出现在cout之前,在绑定后,
每次cin都会先把缓冲区的数据刷新到输出文件中;
顺便补充下关于io流的知识:
在c++中,io操作都是有io对象来实现的,每个io对象又管理一个缓冲区,用于存储程序读写的数据。
只有缓冲区被刷新的时候缓冲区中的内容才会写入真实的文件或输出设备上。
那么,什么情况下会刷新输出缓冲区呢,有如下五种情况:
1.程序正常结束。作为main返回工作的一部分,将清空所有的输出缓冲区。
2.在一些不确定的时候,缓冲区可能已经满了,在这种情况下,缓冲区将会在写下一个值之前刷新。
3.用操纵符显示地刷新缓冲区,如用endl。
4.在每次输出操作执行完毕后,用unitbuf操纵符设置流的内部状态,从而清空缓冲区。
5.可将输出流与输入流关联起来,在读输入流时将刷新其关联的输出缓冲区。
所以关闭流同步后 注意要自己刷新缓冲区
//// ios::sync_with_stdio(0);
//// cin.tie(0);
只有缓冲区被刷新的时候缓冲区中的内容才会写入真实的文件或输出设备上。
那么,什么情况下会刷新输出缓冲区呢,有如下五种情况:
1.程序正常结束。作为main返回工作的一部分,将清空所有的输出缓冲区。
2.在一些不确定的时候,缓冲区可能已经满了,在这种情况下,缓冲区将会在写下一个值之前刷新。
3.用操纵符显示地刷新缓冲区,如用endl。
4.在每次输出操作执行完毕后,用unitbuf操纵符设置流的内部状态,从而清空缓冲区。
5.可将输出流与输入流关联起来,在读输入流时将刷新其关联的输出缓冲区。
所以关闭流同步后 注意要自己刷新缓冲区
//// ios::sync_with_stdio(0);
//// cin.tie(0);