#include<fstream>
#include<iostream>
using namespace std;
int main(){
ofstream fout("student.dat",ios::out);
char name[20],ch;
float marks=0.0;
int i=0;
for(i=0;i<5;i++){
cout<<"Student"<<(i+1)<<" :\tName :";
cin.get(name, 20);
cout<<"\t\tMarks :";
cin>>marks;
cin.get(ch); //Significance of this statement-1?
fout<<name<<"\n"<<marks<<"\n";
}
fout.close();
ifstream fin("student.dat",ios::in);
cout<<"\n";
for(i=0;i<5;i++){
fin.get(name,20);
fin.get(ch); //Significance of this statement-2?
fin>>marks;
fin.get(ch); //Significance of this statement-3?
cout<<"Student Name :"<<name;
cout<<"\tMarks :"<<marks<<"\n";
}
fin.close();
return(0);
}
INPUT-1:程序完全接受输入并提供令人满意的输出。
INPUT-2:程序只接受第一条记录的输入,并在第一次输入后立即输出(从程序中删除语句-1时)。
Student1 : Name :Deepak Marks :10
OUTPUT-1:
Student Name :Deepak Marks :10
Student Name :Sandeep Marks :20
Student Name :Vipin Marks :30
Student Name :Sachin Marks :40
Student Name :Ashish Marks :50
OUTPUT-2:
Student Name :Deepak Marks :10
Student Name : Marks :10
Student Name : Marks :10
Student Name : Marks :10
Student Name : Marks :10
所以现在我的问题是:
1)为什么程序在第二种情况下没有完全输入?
2)哪个导致此行为,cin.getline()或cin?
3)我有部分想法(仍然需要一些明确的解释)cin.get(ch)用于清除缓冲区,但是其他函数的行为方式类似?
答案 0 :(得分:1)
这是因为您正在混合格式化输入(例如cin >> something;
)和未格式化输入(例如cin.get(...)
)。
格式化的输入在读取数据之前滑动所有空格,并在输入后停留在第一个空格处。 [如果您正在读数字,它也将停止不正确的数据,例如“数字”中的字母]。
这些空格留在输入流中,因此如果您使用cin.get(name, 20); cin>> number;
Name<space>Number<newline>
Name<space>Number<newline>
Number的输入将停在<newline>
,当你下一个cin.get(name, 20);
它将读取一个空字符串,因为<newline>
是输入流中的第一个东西。在这两个语句之间添加cin.get()
会读取<newline>
,您将在下一行开始阅读Name