我需要分配未知数量的用户数组,每个用户必须拥有未知数量的数组。所有数据都从CSV文件中读取。
到目前为止,我有:
typedef struct wybor //struct choice
{
char rozmiar_kawy[2];
char czy_z_mlekiem[4];
char ile_cukru[2];
char godzina[20];
}wybor;
typedef struct user
{
char id[5];
char imie[20];
wybor *tablica_wyborow; //dynamic array of struct choice
}user;
void odczyt_z_pliku(user **tab, int n); //reading from file csv
void godzina(user *kawa); //doesnt matter :p
int main()
{
int licznik = 0; //counter for number of users
user *tablica_userow; //dynamic array of struct users
tablica_userow = NULL;
setlocale(LC_ALL, "pl_PL");
odczyt_z_pliku(&tablica_userow, licznik);
getchar();
printf("%s", tablica_userow[0].tablica_wyborow[2].rozmiar_kawy); //check if it works
getchar();
return 0;
}
void odczyt_z_pliku(user **tab, int n)
{
int i = 0;
(*tab) = malloc(1*sizeof(*(*tab)));
tab[n]->tablica_wyborow = malloc(1*sizeof(*(tab[n]->tablica_wyborow)));
FILE *plik;
plik = fopen("users.csv", "a+");
//start reading from file and its working until...
fscanf(plik, "%[^;] ; %[^;] ; %[^;] ; %[^;] ; %[^;] ; %s\n", tab[n]->id, tab[n]->imie, tab[n]->tablica_wyborow[i].rozmiar_kawy, tab[n]->tablica_wyborow[i].czy_z_mlekiem, tab[n]->tablica_wyborow[i].ile_cukru, tab[n]->tablica_wyborow[i].godzina);
i++;
tab[n]->tablica_wyborow = realloc(tab[n]->tablica_wyborow,(i+1)*sizeof(*(tab[n]->tablica_wyborow)));
fscanf(plik, "%[^;] ; %[^;] ; %[^;] ; %[^;] ; %[^;] ; %s\n", tab[n]->id, tab[n]->imie, tab[n]->tablica_wyborow[i].rozmiar_kawy, tab[n]->tablica_wyborow[i].czy_z_mlekiem, tab[n]->tablica_wyborow[i].ile_cukru, tab[n]->tablica_wyborow[i].godzina);
i = 0;
n++;
*tab = realloc(*tab,(n+1)*sizeof(user)); //...now, here there is a memory writing location error
tab[n]->tablica_wyborow = malloc(sizeof(*tab[n]->tablica_wyborow));
fscanf(plik, "%[^;] ; %[^;] ; %[^;] ; %[^;] ; %[^;] ; %s\n", tab[n]->id, tab[n]->imie, tab[n]->tablica_wyborow[i].rozmiar_kawy, tab[n]->tablica_wyborow[i].czy_z_mlekiem, tab[n]->tablica_wyborow[i].ile_cukru, tab[n]->tablica_wyborow[i].godzina);
i++;
tab[n]->tablica_wyborow = realloc(tab[n]->tablica_wyborow, (i + 1) * sizeof(*(tab[n]->tablica_wyborow)));
fscanf(plik, "%[^;] ; %[^;] ; %[^;] ; %[^;] ; %[^;] ; %s\n", tab[n]->id, tab[n]->imie, tab[n]->tablica_wyborow[i].rozmiar_kawy, tab[n]->tablica_wyborow[i].czy_z_mlekiem, tab[n]->tablica_wyborow[i].ile_cukru, tab[n]->tablica_wyborow[i].godzina);
fclose(plik);
}
我不知道为什么我不能正确地重新分配用户数组。
我没有释放内存,因为它在我尝试时崩溃了。
答案 0 :(得分:0)
您可以使用链接列表读取数据。用户数据结构具有指向用户选择的链接列表的指针。
如果您仍然想要使用数组,您现在可以计算用户的数量,为其分配数组并将其填充给用户。以同样的方式,您可以计算用户的选择数量并为其分配数组,然后填充它。
您的链接列表应该有一个void *
成员,该成员将存储指向用户的单独数据结构的指针,因此您只需将用户数据结构的指针从链接列表移动到您的数组。
用户数据结构有一个成员wybor *tablica_wyborow;
供用户选择。您可以维护一个链接列表,该列表将在读取数据时保持用户选择,然后,一旦读取了所有用户的选项,您将对它们进行计数并为其分配数组并复制选择数据(通过值或指针)进入它。
完成所有操作后,请取消分配链接列表,因为您不再需要它们。
另外,您可以读取文件进行计数,然后重新处理。但这会给计算个人用户选择带来问题。