C中动态结构数组中的动态结构数组

时间:2017-02-08 13:00:41

标签: c arrays csv struct realloc

我需要分配未知数量的用户数组,每个用户必须拥有未知数量的数组。所有数据都从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);

}

我不知道为什么我不能正确地重新分配用户数组。

我没有释放内存,因为它在我尝试时崩溃了。

1 个答案:

答案 0 :(得分:0)

您可以使用链接列表读取数据。用户数据结构具有指向用户选择的链接列表的指针。

如果您仍然想要使用数组,您现在可以计算用户的数量,为其分配数组并将其填充给用户。以同样的方式,您可以计算用户的选择数量并为其分配数组,然后填充它。

您的链接列表应该有一个void *成员,该成员将存储指向用户的单独数据结构的指针,因此您只需将用户数据结构的指针从链接列表移动到您的数组。

用户数据结构有一个成员wybor *tablica_wyborow;供用户选择。您可以维护一个链接列表,该列表将在读取数据时保持用户选择,然后,一旦读取了所有用户的选项,您将对它们进行计数并为其分配数组并复制选择数据(通过值或指针)进入它。

完成所有操作后,请取消分配链接列表,因为您不再需要它们。

另外,您可以读取文件进行计数,然后重新处理。但这会给计算个人用户选择带来问题。