C读到文件结束
我目前有读取4行的代码,我希望能够更改它,直到EOF或我的MAX const int值。我拿不到那本书!EOF工作正常,我想知道如何更改代码来实现这一点 提前谢谢C读到文件结束,c,C,我目前有读取4行的代码,我希望能够更改它,直到EOF或我的MAX const int值。我拿不到那本书!EOF工作正常,我想知道如何更改代码来实现这一点 提前谢谢 #include <stdio.h> struct record{ char name[2]; int arrival_time; int job_length; int job_priority; }; const int MAX = 40; int main(void) {
#include <stdio.h>
struct record{
char name[2];
int arrival_time;
int job_length;
int job_priority;
};
const int MAX = 40;
int main(void)
{
struct record jobs[MAX];
int i = 0;
int j;
FILE *f = fopen("data.dat","rb");
while (fscanf(f, "%s %d %d %d", &jobs[i].name, &jobs[i].arrival_time,
&jobs[i].job_length, &jobs[i].job_priority) == 4 && i < MAX)
i++;
for (j = 0; j < i; j++)
printf("%s %d %d %d\n", jobs[j].name, jobs[j].arrival_time,
jobs[j].job_length, jobs[j].job_priority);
fclose(f);
return(0);
}
#包括
结构记录{
字符名[2];
国际到达时间;
int作业长度;
工作优先权;
};
常数int MAX=40;
内部主(空)
{
结构记录作业[MAX];
int i=0;
int j;
文件*f=fopen(“data.dat”、“rb”);
而(fscanf(f,“%s%d%d%d”,&jobs[i]。名称,&jobs[i]。到达时间,
&作业[i]。作业长度和作业[i]。作业优先级)==4&&i
类似
while (fscanf(f, " %s ", &etc) != EOF) {
}
然后使用
feof(f)
检查它是否是fscanf
错误或实际上是EOF
您的代码似乎做了您想做的事情,除了:
char name[2];
名称可能超过1个字符
FILE *f = fopen("data.dat","rb");
您似乎正在读取文本(“r”
)文件,而不是二进制(“rb”
)
&jobs[i]。name
应该是jobs[i]。name
您需要更改while()
循环中的测试顺序-您必须在调用fscanf()
之前测试i
,否则您可能会多次调用它(您还应该传递jobs[i].name
不带和至fscanf
):
while(i
个人而言,我会这样编码:
for(i=0 ; i<MAX ; ++i) {
fscanf(f, "%s %d %d %d", &jobs[i].name, &jobs[i].arrival_time,
&jobs[i].job_length, &jobs[i].job_priority);
if(ferror(f) || feof(f)) break;
}
<代码> >(i=0);IIF要读取直到EOF,并且不预先知道“代码>数据DAT< <代码>文件的行数,那么您应该考虑Stutt:Case< Works<代码>的动态存储(A<代码> MalOC 和一些<代码> ReLoC/<代码>,直到文件结束为止)。在以二进制模式打开的文件上使用fscanf
似乎有些奇怪。fscanf
带有不合格的%s“
格式本质上是不安全的,除非您能够完全控制输入文件中的内容;它读取任意长度的空格分隔字,可能会溢出数组。您的终止条件(检查fscanf
返回的值)似乎是正确的;如果您在每个输入行上有4个数据字段,则应该可以k、 你能给我们看一下data.dat
是什么样子吗?我的data.dat在一行上看起来是这样的A1 3,然后是B1 4 4,依此类推。他已经在检查fscanf
是否返回4(请求的项目数);它最多应该读取40组项目。
for(i=0 ; i<MAX ; ++i) {
fscanf(f, "%s %d %d %d", &jobs[i].name, &jobs[i].arrival_time,
&jobs[i].job_length, &jobs[i].job_priority);
if(ferror(f) || feof(f)) break;
}