использование realloc не будет хранить значения в массиве после выхода из функции


После размещения значений в базе данных в массиве и отправки значений в addReader внутри самой функции, значения сохраняются успешно, однако при возвращении в main введенные значения исчезают.

Задается следующий код: создание динамического массива с помощью realloc

reader* readerBuilder(reader *rdr, int *readNum){       //building all the readers
    FILE *read;
    int i=1;
    char *str;
    read = fopen("Readers.txt","r");
    checkFile(read);
    str = readFromFile(read);
    while(str != NULL)
    {
        rdr[i-1] = *cutToRdr(str);
        str = readFromFile(read);
        if(str != NULL){
            i++;
            rdr = (reader*)realloc(rdr,sizeof(reader)*i);
            checkreader(rdr);
        }
    }
    fclose(read);
    *readNum = i;
    return rdr;
}

Учитывая вызывающую функцию:

reader* addReader(reader *rdr, int *readNum){       //adding a reader from the user
    char string[1000];
    rdr = (reader*)realloc(rdr,sizeof(reader)*(*readNum+1));// build new struct array ( bigger), with the old values
    checkreader(rdr);// check if can get memory
    printf("please enter the I.D. of the student you want to add:n");
    scanf("%s",string);// get from operant
    rdr[*readNum].id=cutToStr(string);// put id in struct
    printf("please add the reader's first name:n");
    scanf("%s",string);// get from operant
    rdr[*readNum].first_name=cutToStr(string);// put first name in struct
    printf("please add the reader's last name:n");
    scanf("%s",string);// get from operant
    rdr[*readNum].last_name=cutToStr(string);// put last name in struct
    printf("please add the reader's address:n");
    scanf("%s",string);// get from operant
    rdr[*readNum].address=cutToStr(string);// put adress in struct
    printf("please add the reader's phone:n");
    scanf("%s",string);// get from operant
    rdr[*readNum].phone=cutToStr(string);// put phone in struct
    rdr[*readNum].numToTake = 5;// change value of numbers to tke to 5
    *readNum = *readNum + 1;// rise the number of the readers
    return rdr;// return the new structs array
}

Учитывая вызов функции в main:

rdr=addReader(rdr,readNum);

Определение структуры читателя:

typedef struct reader{
    int numToTake;
    char *first_name, *last_name, *address, *phone, *id;
}reader;

Что я делаю не так? ? С Уважением, Дэвид

Править!

Все еще не работает. Новая редакция Кодекса:

void addReader(reader **rdr, int *readNum){     //adding a reader from the user
    char string[1000];
    rdr = (reader**)realloc(rdr,sizeof(reader*)*(*readNum+1));// build new struct array ( bigger), with the old values
    checkreader(*rdr);// check if can get memory
    printf("please enter the I.D. of the student you want to add:n");
    scanf("%s",string);// get from operant
    rdr[*readNum]->id=cutToStr(string);// put id in struct
    printf("please add the reader's first name:n");
    scanf("%s",string);// get from operant
    rdr[*readNum]->first_name=cutToStr(string);// put first name in struct
    printf("please add the reader's last name:n");
    scanf("%s",string);// get from operant
    rdr[*readNum]->last_name=cutToStr(string);// put last name in struct
    printf("please add the reader's address:n");
    scanf("%s",string);// get from operant
    rdr[*readNum]->address=cutToStr(string);// put adress in struct
    printf("please add the reader's phone:n");
    scanf("%s",string);// get from operant
    rdr[*readNum]->phone=cutToStr(string);// put phone in struct
    rdr[*readNum]->numToTake = 5;// change value of numbers to tke to 5
    *readNum = *readNum + 1;// rise the number of the readers
    //return rdr;// return the new structs array

}

Новый вызов в main:

addReader(&rdr,readNum);
1 2

1 ответ:

Вы должны проходить **rdr:

reader* addReader(reader **rdr, int *readNum)
                         ^^

Кроме того, это добавляет новый уровень косвенности, когда вы realloc.

С кодом, который у вас теперь есть, вы realloc на копии указателя, а не на фактическом указателе.