cin,cerr,clog,cout

iostream库:包含两个基础类型istreamostream

标准库定义了4个IO对象:
1. cin,标准输入,istream类型对象。
2. cout,标准输出,ostream类型对象。
3. cerr,标准错误,输出警告和错误信息,ostream类型对象。
4. clog,标准错误,输出输出程序运行时的一般信息,ostream类型对象。


c++里cerr,clog,cout三者的区别:
1. cout:在内存中开辟一个缓冲区,用来存放流中的数据。当插入一个endl操纵符,立即输出缓冲区中所有数据,然后插入一个换行符。
2. cerr:没有缓冲,发送给它的内容立即被输出。与cout的不同在于cout一般在显示器输出,但可以被重定向输出到文件,而cerr流中的信息只能在显示器输出。(当内存用完之后还能为用户执行输出操作)
3. clog:有缓冲,缓冲区满或者遇到endl时输出。


关于缓冲区:

endl 被称为操纵符,效果是将与设备相关联的缓冲区中的内容刷新到设备中,具有换行的效果。
程序员经常在调试过程中插入输出语句,这些语句都应该刷新输出流。忘记刷新输出流可能会造成输出停留在缓冲区中,如果程序崩溃,将会导致程序错误推断崩溃位置。

刷新缓冲区:

当以缓冲方式打开一个文件,并向文件中写几个字节时,一般不会立即真正把这几个字节写入文件,只有当刷新缓冲区时才真正写盘。
下列行为会刷新缓冲区:
1)缓冲区满时;
2)行输出时遇endl,cerr或cin时;
3)执行刷新函数;
4)关闭文件。


输出重定向:

#include <iostream>
using namespace std;
int main() {
    cout<<"cout"<<endl;
    cerr<<"cerr"<<endl;
    return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

编译后生成iris.exe,切换到可执行程序所在文件目录下,执行:

iris.exe>test.log
  • 1
  • 2

可以看到在cmd中显示cerr,在生成的test.log文件中只有一行cout,即将cout输出重定向到文件中。


当使用一个istream对象作为判断条件时,其效果是检测流的状态。例如:

int value;
while(std::cin>>value){
    //do something
}
  • 1
  • 2
  • 3
  • 4

如果流是有效的,没有遇到错误,那么检测为真;如果遇到文件结束符(windows为Ctrl+Z,Unix为Ctrl+D)或者无效的输入(读入的值不是一个整数),istream对象的状态会变为无效,检测为假。

原文地址:https://www.cnblogs.com/chmusk/p/11078965.html