本书P15的一个问题,为什么这段代码运行出来后,最后一个数字没有显示
if和while里cin的数据为啥是一样的。不同于cin>>val;cin>>currVal;这样是分别读取自己的
#include<iostream>
using namespace std;
int main()
{
int currVal = 0, val = 0;
if (cin >> currVal)
{
int cnt = 1;
while (cin >> val)
{
if (val == currVal)
++cnt;
else
{
cout << currVal << " occures " << cnt << " times " << endl;
currVal = val;
cnt = 1;
}
}
cout << currVal << " occures " << cnt << " times " << endl;
}
system("pause");
return 0;
}
(1)书P13:
当我们使用一个istream对象作为条件时(while(std::cin>>value){}),其效果是检测流的状态。如果流是有效的,即流未遇到错误,那么检测成功。当遇到文件结 束符(end-of-file),或遇到一个无效输入时,istream对象的状态会变成无效。处于无效状态的istream对象会使条件变为假。(在Windows系统中,输入文件结束符 的方法是敲Ctrl+Z,然后按Enter或Return键。在UNIX系统中,包括Mac OS X系统中,文件结束符输入时用Ctrl+D)
程序最后在while哪里卡主了。因为没有在文件结束时输入结束标志ctrl+z,然后enter;或者是其他的无效输入。
(2)程序的输入都建有一个缓冲区,即输入缓冲区。一次输入过程是这样的,(当我们从键盘输入字符串的时候需要敲一下回车键才能够将这个字符串送入到缓冲区中,)当一次键盘输入结束时(按ctrl+z,然后enter)会将输入的数据存入输入缓冲区,而cin函数直接从输入缓冲区中取数据。正因为cin函数是直接从缓冲区取数据的,所以有时候当缓冲区中有残留数据时,cin函数会直接取得这些残留数据而不会请求键盘输入,而cin是一个一个读取,直到遇到结束符。至于cin>>val;cin>>currVal;这样有分号的结束(分号就代表一条语句的结束)读取一个数据就结束,所以后面是空格也结束,(之前看到有说原因是遇到空格结束,我觉得原因是分号的作用,输入的字符以空格或者enter来分辨每个数和字符)