为什么我们应该在使用 cin.getline() 或 cin 获取输入后使用 cin.get(ch)?

Why should we use cin.get(ch) after taking input using cin.getline() or cin?

#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

输出-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

输出-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) 用于清除缓冲区,但还有其他功能以类似的方式?

这是因为您混合了 cin >> something; 等格式化输入和 cin.get(...) 等未格式化输入。

格式化输入在读取数据前跳过所有空格,并在输入后的第一个空格处停止。 [如果您正在读取数字,它也会停止在不正确的数据上,例如 "number" 中的字母]。

这些空格留在输入流中,因此如果您使用 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