Перераспределение массива char ** в c (сброшено ядро ​​ошибки сегмента) - PullRequest
0 голосов
/ 02 ноября 2018

Я перераспределяю массив char** с каждой записью, и хотя компиляция возвращается чистой, сохраняется только первая запись, и я всегда получаю ошибку сегментации (сбрасывается ядро), когда пытаюсь зарегистрировать четвертую запись.

Вот соответствующий код в main.c:

int main(int argc, char *argv[]) 
{
    int i,sizea,sizeb,choice,letters,check,mistakes,count;
    char C[26][2];
    char **A,**B,a;

    A=(char**)malloc(sizeof(char*));
    *A=(char*)malloc((MAX_CHAR+1)*sizeof(char));

    sizea=1;
    build(&A,&sizea);

    return 0;
}

А вот реализация метода в mylib.c:

void build(char ***A, int *sizea)
{
    *A=(char**)realloc(*A,(*sizea) * sizeof(char*));
    *A[*sizea-1]=(char*)malloc((MAX_CHAR+1)*sizeof(char));

    printf("Give word :");
    scanf("%s",(*A[*sizea-1]));

    (*sizea)++;
}

Большое спасибо за вашу помощь.

edit: аналогичные проблемы в этом методе, которые не были исправлены, выполняя ту же самую вещь

void find(char **A, char ***B, int letters,int sizea, int *sizeb){

int i,j,k,dummy;
char a='a';

  for(i=0;i<(sizea-1);i++){
    printf("here\n");
      if(A[i][letters]=='\0'){
      *B=(char**)realloc(*B,(*sizeb+1) * sizeof(char*));
      (*B)[*sizeb]=(char*)malloc((letters+1)*sizeof(char));
      (*B)[*sizeb-1]=A[i];
      *sizeb++;
      printf("%s\n", (*B)[i]);
    }
  }
}

1 Ответ

0 голосов
/ 02 ноября 2018

Проблема здесь:

scanf("%s",(*A[*sizea-1]));

Оператор индекса массива [] имеет более высокий приоритет, чем оператор разыменования *. Таким образом, вышеприведенные разборы как:

scanf("%s",(*(A[*sizea-1])));

То, что вы хотите:

scanf("%s",((*A)[*sizea-1]));

Аналогично, это:

*A[*sizea-1]=(char*)malloc((MAX_CHAR+1)*sizeof(char));

Должно быть:

(*A)[*sizea-1]=(char*)malloc((MAX_CHAR+1)*sizeof(char));
...