window如何判断cin输入流的结束?
使用while(cin>>str)进行输入的时候,系统是如何判断输入流的结束的?
搜索一番之后,大多数的答案都说系统不会读取ctrl+z,但那个白框框是什么?window读取缓冲区数据的时候,应该是一边读取一边检测的吧?
还有下面这个
为什么第二个无法输入?读取完缓冲区的数据,为什么那些数据还在?endl不是会刷新缓冲区吗?
下面是源代码.谢谢大家了.
#include <iostream>#include <string>
using namespace std;
int main(){
string p1, p2;
while (cin >> p1){
p2 += p1;
}
cout << p2 << endl;
return 0;
}
#include <iostream>
#include <string>
using namespace std;
int main(){
string p1, p2;
cout << "first" << endl;
while (cin >> p1){
p2 += p1;
}
cout << p2 << endl;
cout << '\n' <<"second" <<endl;
while (cin >> p1){
p2 += p1;
}
cout << p2 << endl;
return 0;
}
回答:
1.当ctrl Z单独成行,或者说它前面没有任何字符(包括空格)时表示终止,其他情况他会被识别为一个无意义的字符。windows下的定义,和程序无关。
2.endl是刷新流。由于cin是遇到错误跳出的while循环,所以不用cin.clear()刷新状态位也是没办法重新进入输入的。你第二个程序会输出原来输入的字母,不是因为数据还在流里面,而是因为运行完第一个while,输入数据被保存在了全局对象p2中,同时由于没有重置状态,程序直接跳过了第二个while循环,直接输出了p2的内容
解决办法:两个while循环间加入cin.clear()和cin.sync()(不想换行输入ctrl+z还可以加个cin.ignore())
回答:
linxu :通过
Ctrl+D
设置EOF
即可windows 通过
Ctrl+Z
设置EOF
即可
代码中添加cin.clear()
#include <iostream>#include <string>
using namespace std;
int main(){
string p1, p2;
cout << "first" << endl;
while (cin >> p1){//
p2 += p1;
}
cout << p2 << endl;
cin.clear();//重新清空一下流的标志位,包括EOF
cout << '\n' <<"second" <<endl;
while (cin >> p1){
p2 += p1;
}
cout << p2 << endl;
return 0;
}
EOF的输入
Linux中,在新的一行的开头,按下Ctrl-D,就代表EOF(如果在一行的中间按下Ctrl-D,则表示输出"标准输入"的缓存区,所以这时必须按两次Ctrl-D);
Windows中,
Ctrl-Z
表示EOF。(顺便提一句,Linux中按下Ctrl-Z,表示将该进程中断,在后台挂起,用fg命令可以重新切回到前台;按下Ctrl-C表示终止该进程。)那么,如果真的想输入Ctrl-D怎么办?这时必须先按下Ctrl-V,然后就可以输入Ctrl-D,系统就不会认为这是EOF信号。Ctrl-V表示按"字面含义"解读下一个输入,要是想按"字面含义"输入Ctrl-V,连续输入两次就行了。
以上是 window如何判断cin输入流的结束? 的全部内容, 来源链接: utcz.com/p/191371.html