C++学习笔记28:输入与输出

1 与输入输出相关的类

    (1)
                        --> ifstream
            --> istream
        ios             --> iostream --> fstream
            --> ostream:
                        --> ofstream
    (2)cin是istream的对象, cout是ostream的对象
    (3)ifstream:对文件进行读操作,ofstream:对文件进行写操作
    (4)fstream:打开文件,进行读写操作都可以

2 与输入输出流操作相关的类

    -- istream用于输入的流类,cin就是该类对象。
    -- ostream用于输出的流类,cout就是该类的对象。
    -- ifstream用于从文件读取数据的类
    -- ofstream用于从文件写入数据的类
    -- iostream是既能用于输入,也能用于输出的类
    -- fstream时既能从文件读取数据,又能向文件写入数据

3 标准流对象

    -- 输入流对象:cin 与标准输入设备相连接
    -- 输出流对象:cout 与标准输出设备相连接
    --           cerr 与标准错误输出设备相连接
    --           clog 与标准错误输出设备相连接
    缺省情况下
        cerr << "Hello" << endl;
        clog << "Hello" << endl;
    和
        cout << "Hello" << endl;    一样
    -- cin对应于标准输入流,用于从键盘读取数据,也可以被重定向为从文件中读取数据
    -- cout对应于标准输出流,用于向屏幕输出数据,也可以被重定向为向文件写入数据
    -- cerr对应于标准错误输出流,用于向屏幕输出出错信息
    -- clog对应于标准错误输出流,用于向屏幕输出出错信息
    -- cerr和clog的区别在于cerr不使用缓冲区,直接向显示器输出信息;而输出到clog中的信息先会被存放在缓冲区,缓冲区满或者刷新时才输出到屏幕

4 输出重定向例子(见本工程shuchu1.cpp)

//
// 输出重定向例子
//
#include <iostream>

using namespace std;

int main()
{
    int x, y;
    cin >> x >> y;
    // 将标准输出设备stdout重定向到了text.txt  w代表写  这样如果交给cout输出的信息就会出现在text.txt这个文件中,而不会出现在屏幕
    freopen("text.txt","w",stdout); // 将标准输出重定向到text.txt文件
    if(y == 0)  // 除数为0则在屏幕上输出错误信息
        cerr << "error." << endl;   // cerr 缺省的情况下输出到屏幕,并没有被重定向
    else
        cout << x/y;    // 输出结果到text.txt
    return 0;
}



5 输入重定向例子(见本工程shuru1.cpp)

//
// 输入重定向例子
//
#include <iostream>

using namespace std;

int main()
{
    double f;
    int n;
    // stdin代表标准输入设备
    freopen("text.txt", "r", stdin);   // cin被改为从t.txt中读取数据
    cin >> f >> n;
    cout << f << "," << n << endl;
    return 0;
}


6 判断输入流结束

    可以用如下方法判断输入流结束:
        int x;
        while(cin >> x){
            ...
        }
        return 0;
    问题: 根据右移运算符在istream类中的重载,它的返回值应该是istream的引用,也就是说这个表达式的返回值应该是cin的引用,也就是cin
          那么cin怎么可以作为条件?
        istream& operator >> (int a)
        {
            ......
            return* this;
        }
    解答:用到了强制类型转换运算符的重载,在istream中有个强制类型转换运算符的重载就能将cin对象强制转换成bool类型值,当输入结束的时候,cin被强制转换成布尔类型的false,while循环就会结束
    (1)如果是从文件输入,比如前面有freopen("some.txt", "r", stdin);那么,读取到文件末尾,输入流就算结束
    (2)如果从键盘输入,则在单独一行输入Ctrl + Z代表输入流结束

7 istream类的成员函数

    (1)istream& getline(char* buf, int bufSize);
        从输入流中读取bufSize-1个字符到缓冲区buf,或读到碰到‘\n’为止(哪个先到算哪个)
    (2)istream& getline(char* buf, int bufSize, char delim);
        从输入流中读取bufSize-1个字符到缓冲区buf, 或读到喷到delim字符为止(哪个先到算哪个)
    (3)两个函数都会自动在buf中读入数据的结尾添加\0。‘n’或者delim都不会被读入buf,但会被从输入流中取走。
        如果输入流中‘\n’或delim之前的字符个数达到或超过了bufSize个,就导致读入出错,其结果就是:虽然本次读入已经完成,但是之后的读入就会失败了
    (4)可以用if(!cin.getline(...))判断输入是否结束
    (5)bool eof();  // 判断输入流是否结束
    (6)int peek();  // 返回下一个字符,但不从流中去掉
    (7)istream& putback(char c);    // 将字符c放回输入流
    (8)istream& ignore(int nCount = 1, int delim = EOF);
        从流中删掉最多nCount个字符,遇到EOF时结束。
    (9)使用getline经常碰到的问题(见本工程istream1.cpp)
//
// istream类中使用getline会经常碰到的问题
//
#include <iostream>

using namespace std;

int main()
{
    int x;
    char buf[100];
    cin >> x;
    cin.getline(buf, 90);
    cout << buf << endl;
    return 0;
}

/**
 * 结果描述
 * 输入:
 * 12 abcd 回车
 * 输出:
 * 空格 abcd
 *
 * 输入:
 * 12回车   即使没有任何语句读取到buf,getline依然在buf中输入'\0'
 * 程序立即结束
 * 输出:
 *
 */

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值