当标题说我遇到崩溃时,当然是在调用beolvas()时。你可能会得到我在这里想做的事情,它也很简单。我正在使用mingw32 btw。感谢您提前提供任何帮助!
typedef struct
{
int kerSzam;
int voteCount;
char *lastName;
char *firstName;
char *party;
} Vote;
void beolvas(Vote t[], int *n)
{
FILE *in;
in = fopen("szavazatok.txt", "r");
while(!feof(in))
{
fscanf(in,
"%d %d %s %s %s\n",
&t[*n].kerSzam,
&t[*n].voteCount,
t[*n].lastName,
t[*n].firstName,
t[*n].party
);
(*n)++;
}
fclose(in);
}
szavazatok.txt看起来像这样:
2 53 first last zed
1 5 first last pet
...
答案 0 :(得分:1)
正如@ Jean-BaptisteYunès评论的那样,需要为字符串分配内存。
建议测试fscanf()
的结果。
void beolvas(Vote t[], int *n, int maxn) {
FILE *in;
in = fopen("szavazatok.txt", "r");
if (in) {
char lastName[50];
char firstName[50];
char party[50];
int cnt = 0;
// spaces not needed in format, but widths are very useful
while(*n < maxn && (cnt = fscanf(in, "%d%d%49s%49s%49s",
&t[*n].kerSzam, &t[*n].voteCount, lastName, firstName, party)) == 5) {
t[*n].lastName = strdup(lastName);
t[*n].firstName = strdup(firstName);
t[*n].party = strdup(party);
(*n)++;
}
fclose(in);
}
}
由于strdup()
是非标准的,如果需要,这是一个实现。
char *strdup(const char *src) {
if (src) {
size_t size = strlen(src) + 1;
char *p = malloc(size);
if (p) {
return memcpy(p, src, size);
}
}
return 0;
}