C++ cout cerr 和 clog 的區別


我們都知道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:以上內容來自網絡,未得到驗證,僅供學習參考。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM