《转》cout和printf的混用而产生的顺序问题
原文地址:http://blog.renren.com/blog/340275217/731966815?作者:趙越
之前對(duì)于cout與printf()混用的結(jié)果的認(rèn)識(shí),源于某年北京賽區(qū)某judge的總結(jié)。據(jù)其稱(chēng),某隊(duì)在比賽時(shí)某題的輸出混用了cout與printf(),結(jié)果輸出的順序出錯(cuò)。其把原因歸結(jié)為一個(gè)帶緩沖而一個(gè)不帶緩沖。對(duì)此金強(qiáng)提出了置疑,因?yàn)閟tdio.h中定義了像ungetc()這樣的函數(shù),其作用是將字符放回到輸入流中。可見(jiàn)stdio中也是使用了緩沖的。那么為什么cout與printf()混用會(huì)發(fā)生問(wèn)題呢?
下面來(lái)做一些試驗(yàn)(環(huán)境:g++ (GCC) 3.2.3 (mingw special 20030504-1))。
#include <iostream> using namespace std;
int main() { ??? cout << "aaa"; ??? printf("bbb"); ??? return 0; }
輸出為:
aaabbb
沒(méi)有問(wèn)題。
如果將程序修改一下:
#include <iostream> using namespace std;
int main() { ??? ios::sync_with_stdio(false); ??? cout << "aaa"; ??? printf("bbb"); ??? return 0; }
輸出成了:
bbbaaa
順序發(fā)生了錯(cuò)誤。
sync_with_stdio()是在<ios_base>中定義的,當(dāng)其接受true作為參數(shù)時(shí),將會(huì)同步iostream與stdio中的流操作。默認(rèn)是true,因此第一個(gè)程序的結(jié)果是正確的。然而,盡管C++標(biāo)準(zhǔn)中規(guī)定stdio sync標(biāo)志默認(rèn)是true,不同平臺(tái)下的不同編譯器可能并不完全支持這個(gè)標(biāo)準(zhǔn)。因此也就有了通常意義上的關(guān)于“不要混用iostream與stdio”之類(lèi)的警告。
如果再修改一下程序:
#include <iostream> using namespace std;
int main() { ??? ios::sync_with_stdio(false); ??? cout << "aaa" << flush; ??? printf("bbb"); ??? return 0; }
這回程序的輸出就又正確了。因?yàn)閒lush強(qiáng)制清空了緩沖區(qū),將其中的內(nèi)容輸出。
轉(zhuǎn)載于:https://www.cnblogs.com/Lyush/articles/3281334.html
總結(jié)
以上是生活随笔為你收集整理的《转》cout和printf的混用而产生的顺序问题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: POJ 3280 Cheapest Pa
- 下一篇: 手机信号放大器 让手机信号增强的办法