Двойной указатель со строками в c / указатели на массив с помощью malloc

Может ли кто-нибудь объяснить мне, почему в моем выводе отсутствует первый указатель (stringarray [0]) и как его решить. также я хотел бы знать, как я могу освободить свою память от всех указателей malloc.

int main(int argc, char **argv) {

[...]

char ** stringarray;
if (( stringarray = (char **)malloc(counter*sizeof(char)))== NULL){exit(0);}

int k = 0;
for (i = 0; i < len; i =i+1){
    if((strcmp(countries, districts[i]) == 0) && ( argvIntPeoplelimit <= people[i])) {
        if (( stringarray[k] = (char * ) malloc(100*sizeof(char)))== NULL){exit(0);}

        snprintf(stringarray[k],100,"The Country %s has %d people.",countries[i],people[i]);
        printf("%d %d %s %s %d\n",i,k,stringarray[k], countires[i],people[i] ); //here stringarray[k] k==0 has a value
        k=k+1;
    }  
}
write_file(stringarray,counter);
for (int f = 0; f < k; ++f)
{
    // if i call stringarray[0] nothing shows up


    //ERROR can't free(stringarray);

}
    return 0;
}

Я не знаю, как построить указатели на структуры со строками, которые позволяют мне обрабатывать данные до "char * result []" функции write_file.

void write_file(char *result[], int len);

Любая помощь, советы, подсказки приветствуются! Спасибо!

1
0
88
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Зачем все усложнять Избегайте выделения памяти, если вы намерены сбросить данные в файл.

for (i = 0; i < len; i =i+1){
if((strcmp(countries, districts[i]) == 0) && ( argvIntPeoplelimit <= people[i])) {
    char country_inf[256] = {0};
    int info_len;
    info_len = snprintf(country_inf,sizeof(country_inf),"The Country %s has %d people.",countries[i],people[i]);
    write_file(country_inf,info_len);
}  

}

write_file должен открывать файл в режиме добавления и записывать новые данные в файл. Нет распределения нет бесплатно

Тем не менее, если вы хотите использовать. Ваше первое распределение неверно. Это должно быть sizeof (char *)

stringarray = (char **)malloc(counter*sizeof(char*))

Вы можете помочь мне здесь снова? Скажем, я, к сожалению, не могу добавить в файл - просто запишите все данные за один вызов - и выделение памяти также является обязательным: (Дело в том, чтобы понять указатели. Int counter сообщает мне, сколько результатов найдено с помощью strcmp ( ), которая запускается здесь второй раз ... которая используется, равна k. Может быть проблема в том, что выделение строкового массива и строкового массива [0] является одним и тем же адресом?

user2853437 26.10.2018 07:42
Ответ принят как подходящий

Я считаю, что это правильный способ выделения памяти для массива строк:

// number of pointers/strings; don't have to cast the result of malloc
char** stringArray = malloc(sizeof(char*) * 2);

// allocate however many chars for each pointer
for(i = 0; i < 2; ++i)
    stringArray[i] = malloc(sizeof(char) * 10);

strcpy(stringArray[0], "Hello");
strcpy(stringArray[1], "world!");

printf("%s %s\n", stringArray[0], stringArray[1]);

А чтобы освободить вышеперечисленное, сделайте следующее:

for(i = 0; i < 2; ++i)
    free(stringArray[i]);

free(stringArray);

Не могли бы вы соответственно добавить в свой код, что он принимает значения из snprintf ()?

user2853437 26.10.2018 10:11

Другие вопросы по теме