C++中cout,cerr,clog的区别

来源:互联网 发布:hosts 一个域名多个ip 编辑:程序博客网 时间:2024/04/25 13:25
C++标准库定义了4个IO对象,cin,cout,cerr,clog .cin 为标准输入,cout,cerr,clog都是输出流对象,三者有什么区别呢?
cout 与cerr的主要区别是cout的输出信息可以被重定向,而cerr则只能输出到标准输出(显示器)上。

 例如下面程序编译后生成test.exe   

  //     test.cpp   
  #include      

  int   main()   

  {   

              cout   <<   "hello   world---cout"   <<   endl   ;   

              cerr   <<   "hello   world---cerr"   <<   endl   ;   

              return   0;   

  }   


在命令行模式下键入下面的命令:   

  test   >>cout.txt 


  运行结果是:   

  在生成的cout.txt文件中输出了"hello   world---cout"   

  同时在显示器上输出了"hello   world---cerr"   

  也就是说cout的输出可以重定向到一个文件中,而cerr必须输出在显示器上。 

clog流也是标准错误流,作用和cerr一样,区别在于cerr不经过缓冲区,直接向显示器输出信息,而clog中的信息存放在缓冲区,缓冲区满或者遇到endl时才输出.   



对于为什么有cerr和clog

比如,你的程序遇到调用栈用完了的威胁(无限,没有出口的递归)。



你说,你到什么地方借内存,存放你的错误信息?



所以有了cerr。其目的,就是在你最需要它的紧急情况下,还能得到输出功能的支持。



缓冲区的目的,就是减少刷屏的次数——比如,你的程序输出圣经中的一篇文章。不带缓冲的话,就会每写一个字母,就输出一个字母,然后刷屏。有了缓冲,你将看到若干句子“同时”就出现在了屏幕上(由内存翻新到显存,然后刷新屏幕)。
原创粉丝点击