我們都知道C++預定義了cin(標准輸入流)和cout(標准輸出流)。但今天突然又蹦出來兩個cerr(標准錯誤流(非緩沖))和clog(標准錯誤流(緩沖))
,本着學習提高的態度在網上搜索了相關內容,下面是從百度知道獲取的內容
ps:不知道是不是會侵權呀......
首先通過一個例子就可以分析cout與cerr的區別,將下面代碼編譯鏈接后生成test.exe
1 #include <iostream.h> 2 3 int main() 4 { 5 cout << "hello world---cout" << endl ; 6 cerr << "hello world---cerr" << endl ; 7 return 0; 8 }
在命令行模式下鍵入下面的命令: test >>cout.txt
運行結果是:
在生成的cout.txt文件中輸出了"hello world---cout"
同時在顯示器上輸出了"hello world---cerr"
也就是說cout的輸出可以重定向到一個文件中,而cerr必須輸出在顯示器上。
再分析下cerr與clog的區別,兩者都是標准錯誤流, 區別在於cerr不經過緩沖區,直接向顯示器輸出信息,而clog中的信息存放在緩沖區,緩沖區滿或者遇到endl時才輸出.
至於為什么有cerr和clog(我感覺這才是重點),比如,你的程序遇到調用棧用完了的威脅(無限,沒有出口的遞歸),你說,你到什么地方借內存,存放你的錯誤信息?
所以有了cerr。其目的,就是在你最需要它的緊急情況下,還能得到輸出功能的支持。
緩沖區的目的,就是減少刷屏的次數——比如,你的程序輸出聖經中的一篇文章。不帶緩沖的話,就會每寫一個字母,就輸出一個字母,然后刷屏。有了緩沖,你將看到
若干句子“同時”就出現在了屏幕上(由內存翻新到顯存,然后刷新屏幕)。
pps:以上內容來自網絡,未得到驗證,僅供學習參考。