c++标准I/O输入流

标准I/O对象:cin,cout,cerr,clog
cout流对象
cont是console output的缩写,意为在控制台(终端显示器)的输出。强调几点。

  1. cout不是C++预定义的关键字,它是ostream流类的对象,在iostream中定义。 顾名思义,流是流动的数据,cout流是流向显示器的数据。cout流中的数据是用流插入运算符“<<”顺序加入的。如果有
    cout<<"I "<<"study C++ "<<"very hard. << “wang bao ming ";
    按顺序将字符串"I ", "study C++ ", "very hard.“插人到cout流中,cout就将它们送到显示器,在显示器上输出字符串"I study C++ very hard.”。cout流是容纳数据的载体,它并不是一个运算符。人们关心的是cout流中的内容,也就是向显示器输出什么。
    2)用“ccmt<<”输出基本类型的数据时,可以不必考虑数据是什么类型,系统会判断数据的类型,并根据其类型选择调用与之匹配的运算符重 载函数。这个过程都是自动的,用户不必干预。如果在C语言中用prinf函数输出不同类型的数据,必须分别指定相应的输出格式符,十分麻烦,而且容易出 错。C++的I/O机制对用户来说,显然是方便而安全的。
  2. cout流在内存中对应开辟了一个缓冲区,用来存放流中的数据,当向cout流插 人一个endl时,不论缓冲区是否已满,都立即输出流中所有数据,然后插入一个换行符, 并刷新流(清空缓冲区)。注意如果插人一个换行符”\n“(如cout<<a<<"\n"),则只输出和换行,而不刷新cout 流(但并不是所有编译系统都体现出这一区别)。
  3. 在iostream中只对"<<“和”>>“运算符用于标准类型数据的输入输出进行了重载,但未对用户声明的类型数据的输入输出 进行重载。如果用户声明了新的类型,并希望用”<<“和”>>"运算符对其进行输入输出,按照重运算符重载来做。
    cerr流对象
    cerr流对象是标准错误流,cerr流已被指定为与显示器关联。cerr的 作用是向标准错误设备(standard error device)输出有关出错信息。cerr与标准输出流cout的作用和用法差不多。但有一点不同:cout流通常是传送到显示器输出,但也可以被重定向 输出到磁盘文件,而cerr流中的信息只能在显示器输出。当调试程序时,往往不希望程序运行时的出错信息被送到其他文件,而要求在显示器上及时输出,这时 应该用cerr。cerr流中的信息是用户根据需要指定的。
    clog流对象
    clog流对象也是标准错误流,它是console log的缩写。它的作用和cerr相同,都是在终端显示器上显示出错信息。区别:cerr是不经过缓冲区,直接向显示器上输出有关信息,而clog中的信息存放在缓冲区中,缓冲区满后或遇endl时向显示器输出。

缓冲区的概念:
在这里插入图片描述

1标准输入流
标准输入流对象cin,重点掌握的函数
cin.get() //一次只能读取一个字符
cin.get(一个参数) //读一个字符
cin.get(三个参数) //可以读字符串
cin.getline()
cin.ignore()
cin.peek()
cin.putback()
标准输入流常见api编程案例
//1 cin cout能根据类型 获取数据 / 输出数据
//2 输入字符串 你 好 遇见空格,停止接受输入
void main01()
{
char YourName[50];
int myInt;
long myLong;
double myDouble;
float myFloat;
unsigned int myUnsigned;
cout << "请输入一个Int: ";
cin >> myInt;
cout << "请输入一个Long: ";
cin >> myLong;
cout << "请输入一个Double: ";
cin >> myDouble;
cout << "请输入你的姓名: ";
cin >> YourName;
cout << “\n\n你输入的数是:” << endl;
cout << “Int: \t” << myInt << endl;
cout << “Long: \t” << myLong << endl;
cout << “Double: \t” << myDouble << endl;
cout << “姓名: \t” << YourName << endl;
cout<< endl << endl;
system(“pause”);
return ;
}

//1 输入英文 ok
//2 ctr+z 会产生一个 EOF(-1)
int main02()
{
char ch;
while( (ch= cin.get())!= EOF)
{
std::cout << "字符: " << ch << std::endl;
}
std::cout << “\n结束.\n”;
system(“pause”);
return 0;
}

//演示:读一个字符 链式编程
void main03()
{
char a, b, c;
cin.get(a);
cin.get(b);
cin.get©;
cout << a << b << c<< endl;
cout << “开始链式编程” << endl;
cout.flush();
cin.get(a).get(b).get©;
cout << a << b << c<< endl;
system(“pause”);
return ;
}

//演示cin.getline() 可以接受空格
void main04()
{
char buf1[256];
char buf2[256];
cout << “\n请输入你的字符串 不超过256” ;
cin.getline(buf1, 256, ‘\n’);
cout << buf1 << endl;
//
cout << "注意: cin.getline() 和 cin >> buf2 的区别, 能不能带空格 " << endl;
cin >> buf2 ; //流提取操作符 遇见空格 停止提取输入流
cout << buf2 << endl;
system(“pause”);
}

//缓冲区实验
/*
1 输入 “aa bb cc dd” 字符串入缓冲区
2 通过 cin >> buf1; 提走了 aa
3 不需要输入 可以再通过cin.getline() 把剩余的缓冲区数据提走
*/
void main05()
{
char buf1[256];
char buf2[256];
cout << “请输入带有空格的字符串,测试缓冲区” << endl;
cin >> buf1;
cout << “buf1:” << buf1 << endl;
cout << “请输入数据…” << endl;
//缓冲区没有数据,就等待; 缓冲区如果有数据直接从缓冲区中拿走数据
cin.getline(buf2, 256);
cout << “buf2:” << buf2 << endl;
system(“pause”);
}

// ignore 和 peek
void main06()
{
int intchar;
char buf1[256];
char buf2[256];
cout << "请输入带有空格的字符串,测试缓冲区 aa bb cc dd ee " << endl;
cin >> buf1;
cout << “buf1:” << buf1 << endl;
cout << “请输入数据…” << endl;
cin.ignore(2);
//intchar = cin.peek();
//cout << “缓冲区若有数据,返回第一个数据的asc码:” << intchar << endl;
//缓冲区没有数据,就等待; 缓冲区如果有数据直接从缓冲区中拿走数据
cin.getline(buf2, 256);
cout << “buf2:” << buf2 << endl;
intchar = cin.peek(); //没有缓冲区 默认是阻塞模式
cout << “缓冲区若有数据,返回第一个数据的asc码:” << intchar << endl;
system(“pause”);
}

//案例:输入的整数和字符串分开处理
int main07()
{
cout << "Please, enter a number or a word: ";
char c = std::cin.get();
if ( (c >= ‘0’) && (c <= ‘9’) ) //输入的整数和字符串 分开处理
{
int n; //整数不可能 中间有空格 使用cin >>n
cin.putback ©;
cin >> n;
cout << "You entered a number: " << n << ‘\n’;
}
else
{
string str;
cin.putback ©;
getline (cin,str); // //字符串 中间可能有空格 使用 cin.getline();
cout << "You entered a word: " << str << ‘\n’;
} system(“pause”);
return 0;
}

猜你喜欢

转载自blog.csdn.net/it_xiangqiang/article/details/109215004