0

现在我正在为一个课程做一个程序,但我不能让 inf.eof 工作。数据文件为:

Julie 100 100 100 100 100
Sam 90 0 100 95 90
Trudy 85 77 100 87 81
Will 85 81 0 89 72
George 81 83 100 79 55
Hannah 87 90 100 99 95
Cathy 93 96 95 82 65
Hal 65 71 0 75 88
Xena 100 100 100 100 0

代码是:

#include <iostream>
#include <fstream>
#include <string>
#include <iomanip>
#include <assert.h>
using namespace std;
double score;

double getave(int a,int b)
{
        double average;
        average = 1.0 * (a + b)/2;
        return average;
}

void getclassave()
{

}

double getgrade(double score)
{
    double grade;
if(score >= 90)
    grade = 'A';
else if(score >=80)
    grade = 'B';
else if(score >= 70)
    grade = 'C';
else if(score >= 60)
    grade = 'D';
else
    grade = 'F';
return grade;
}

void printtitles()
{

}



void main()
{
ifstream inf;
    inf.open("input.data");
ofstream outf;
    outf.open("data.out");
outf.setf(ios::fixed);
outf.precision(2);
double name, qu1, qu2, prg1, prg2, fnl;
while(!inf.eof())
{   
    inf >> name >> qu1 >> qu2 >> prg1 >> prg2 >> fnl;
    cout << name << endl;
}
system("pause");
}

我现在只在处理 void main(),因为我需要能够读取文件来完成剩下的工作。我希望“whine(!inf.eof())”循环直到它读取最后一行数据,然后通过在输出文件的新行上打印所有名称来显示它是否有效。但现在它会导致一个无限循环,在我的输出文件中输出无限行“-92559631349317830000000000000000000000000000000000000000000000.00”。我在这里做错了什么?

4

3 回答 3

3

这应该工作: -

while(inf >> name >> qu1 >> qu2 >> prg1 >> prg2 >> fnl)
{   

    cout << name << endl;
}
于 2013-09-26T19:24:32.717 回答
3

stream.eof()用于控制输入循环几乎总是错误的,您需要非常准确地知道eof()在这种情况下要使用什么。在所有情况下,您总是希望在尝试从流中读取检查您的输入是否成功:

while (inf >> name >> qu1 >> qu2 >> prg1 >> prg2 >> fnl) {
    std::cout << name << '\n';
}
于 2013-09-26T19:26:41.590 回答
0

看起来你需要一些对诊断更友好的东西:

while (inf >> name)
{
  inf >> qu1;
  if (!inf.good())
  {
      std::cerr << "Error reading qu1.\n";
      break;
  }
  inf >> qu2;
  if (!inf.good())
  {
      std::cerr << "Error reading qu2.\n";
      break;
  }
//....

是的,您可以在一个语句中读取所有变量,但这使得确定失败的位置变得困难。在一条语句中阅读所有内容时,您不知道哪个变量导致了失败。

于 2013-09-26T19:57:16.183 回答