为什么我们应该在使用 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
#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