c - 读取文件时使用 realloc()

标签 c while-loop realloc

每次 while 循环读取一组数据时,我都尝试使用 realloc 为数组分配更多内存。

这就是函数

void loadStats(Database *db){
  FILE *file = fopen("stats.txt", "r");
  int i = 0;
  while (fscanf(file,"%s %d/%d %d.%d %s - %s %d - %d %f", 
    &db[i].dayname, &db[i].day, &db[i].month, &db[i].hour, &db[i].minute,
    &db[i].hometeam, &db[i].awayteam, &db[i].homescore, &db[i].awayscore, &db[i].spectators) != EOF){
    db[i].spectators = db[i].spectators * 1000;
    i++;
    db = realloc(db, sizeof(db) + sizeof(Database));
  }
  fclose(file);
}

这是我正在尝试读取的文件:stats.txt

#include <stdio.h>
#include <stdlib.h>

typedef struct{
  char dayname[3];
  int day;
  int month;
  int hour;
  int minute;
  char hometeam[3];
  char awayteam[3];
  int homescore;
  int awayscore;
  float spectators;
} Database;

void loadStats(Database *db);
void printStats(Database *db);

int main(){
  Database *db = malloc(sizeof(Database));
  loadStats(db);
  printStats(db);
  return 0;
}

void loadStats(Database *db){
  FILE *file = fopen("stats.txt", "r");
  int i = 0;
  while (fscanf(file,"%s %d/%d %d.%d %s - %s %d - %d %f", 
    &db[i].dayname, &db[i].day, &db[i].month, &db[i].hour, &db[i].minute,
    &db[i].hometeam, &db[i].awayteam, &db[i].homescore, &db[i].awayscore, &db[i].spectators) != EOF){
    db[i].spectators = db[i].spectators * 1000;
    i++;
    db = realloc(db, sizeof(db) + sizeof(Database));
  }
  fclose(file);
}

void printStats(Database *db){
    int i;
    printf("Enter array number.\n");
    scanf("%d", &i);
    printf("db[%d].dayname = %s\ndb[%d].day = %d\ndb[%d].month = %d\ndb[%d].hour = %d\ndb[%d].minute = %d\n"
           "db[%d].hometeam = %s\ndb[%d].awayteam = %s\ndb[%d].homescore = %d\ndb[%d].awayscore = %d\ndb[%d].spectators = %f\n\n", 
            i, db[i].dayname, i, db[i].day, i, db[i].month, i, db[i].hour, i, db[i].minute,
            i, db[i].hometeam, i, db[i].awayteam, i, db[i].homescore, i, db[i].awayscore, i, db[i].spectators);
}

编辑:问题是这会崩溃,我尝试过不使用 realloc,而只是使用 malloc 分配固定数量,这是可行的,但是如果数据增加,则不会。所以我试图让代码适应读取的数据量。

最佳答案

首先,我告诉你

 db = realloc(db, sizeof(db) + sizeof(Database));

是非常糟糕的编码方式,如果realloc()失败,您最终也会丢失实际的指针。完成工作的更好方法是(伪代码)

Database * temp = NULL;
temp = realloc(db, sizeof(db) + sizeof(Database));
if (temp)
  db = temp;

也就是说,db 是一个指针,sizeof(db) 将始终为您提供指针的大小,而不是分配给它的内存量。在 realloc() 中使用新大小时,您必须维护和更新保存大小的单独计数器。类似的东西

 realloc(db, counter * sizeof(Database));  //counter is updated after every allocation

应该为你完成这项工作。

关于c - 读取文件时使用 realloc(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33971229/

相关文章:

c++ - 修复不良 while-switch 循环的方法?

c - 将int数组在内存中的新空间重新分配为0

swift - 使用 Float 数组在 Swift 中调用 "realloc"的正确方法?

c - 使用 C 从路由器转储闪存

c - ungetc() 是否不写入文件,而只是移动文件位置?

c - 交叉编译 poppler 包时出错

Java For循环到递归函数

c - 8051 无法转储十六进制文件

java - Android-java 条件检查错误 - 需要纠正一些代码逻辑

c - 从文本文件中逐字符读取多行时出现段错误