zoukankan      html  css  js  c++  java
  • 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对象的状态会变为无效,检测为假。

  • 相关阅读:
    request-log-analyzer日志分析
    ubuntu下git输出的颜色变化
    vundle安装 给vim插上翅膀
    安装ruby
    【HDU1944】S-Nim-博弈论:SG函数
    【HDU1944】S-Nim-博弈论:SG函数
    我对SG函数的理解
    我对SG函数的理解
    【POJ2154】Color-Polya定理+欧拉函数
    【POJ2154】Color-Polya定理+欧拉函数
  • 原文地址:https://www.cnblogs.com/chmusk/p/11078965.html
Copyright © 2011-2022 走看看