Почему я получаю ошибку сегментации 11? - PullRequest
0 голосов
/ 23 апреля 2019

Я получаю ошибку сегментации 11 в моей функции printArr, хотя я не знаю причину этого. Мой код компилируется. Нет ошибки сегментации, если я не включаю функцию printArr. Любая помощь будет принята с благодарностью.

void printArr(int* arr, int arrlen){
  printf("{");
  for(int i = 0; i < arrlen; i++){
    printf("%d,", arr[i]);
  }
  printf("}\n");
}

int countDeLen (int* in, unsigned int inlen){
  int counter = 0;
  if (inlen % 2 == 1){
    return -1;
  }
  if (inlen == 0){
    return 0;
  }
  int i = 0;
  while (i < inlen){
    counter += in[i];
    i += 2;
  }
  return counter;
}

void rle_decode(int* in, unsigned int inlen, int** out, unsigned int* outlen){
  outlen[0] = countDeLen(in,inlen);
  if(outlen[0] == -1){
    fprintf(stderr, "the code must have an even length!!!\n");
    exit(1);
  }
  int* outCode = (int*)malloc(outlen[0] * sizeof(int));
  out = (int**)malloc(outlen[0] * sizeof(int));
  if(outlen[0] == 0){
    return;
  }
  int codeIndex = 0;
  int i = 0;
  while(i < inlen){
    for(int a = 0; a < in[i]; a++){
      outCode[codeIndex] = in[i+1];
      codeIndex++;
    }
    i+=2;
  }
  out[0] = outCode;
  return;
}

int main(int argc, char *argv[])
{
  printf("testing rle_decode()\n");
  int dtest1[] = {2,1,3,4,2,3}; unsigned int dlen1 = 6; int *out1; unsigned int outlen;
  rle_decode(dtest1, dlen1, &out1, &outlen);
  printArr(*out1,outlen);
}

Я получаю ошибку сегментации 11 в моей функции printArr, хотя я не знаю причину этого. Мой код компилируется. Нет ошибки сегментации, если я не включаю функцию printArr. Любая помощь будет принята с благодарностью.

1 Ответ

3 голосов
/ 23 апреля 2019

Вы не правильно звоните printArr(). Должно быть:

printArr(out1,outlen);

Ваш код эквивалентен звонку

printArr(out1[0], outlen);

Но printArr() требует, чтобы первым аргументом был указатель на массив int, а не один int.

Вы должны были получить предупреждение о несоответствии типов.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...