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'
* 程序立即结束
* 输出:
*
*/