Неверный размер записи: memset

void readdat (int c, char **v) {

char *dc;
char *pdc;

dc = malloc((line+1) * sizeof(char));
memset(dc, 0, (line+1) * sizeof(char));

FILE *datfile;
datfile = fopen(v[3], "r");

while(fgets(dc, line, datfile) != NULL) {
 pdc = strtok(dc, "\t");
 countcDat = 0;
 while(pdc != NULL) {
  ++countcDat;
  pdc = strtok(NULL, "\t");
 }
 ++countrDat;
}

dat = malloc(countrDat * sizeof(char**));
memset(dat, 0, countrDat * sizeof(char**));

for(i=0;i<countrDat;++i) {
 dat[i] = malloc(countcDat * sizeof(char*));
 memset(dat[i], 0, countcDat * sizeof(char*));
}

for(i=0;i<countrDat;++i) {
 for(j=0;j<countcDat;++j) {
  dat[i][j] = malloc(20 * sizeof(char));
  memset(dat[i][j], 0, 20 * sizeof(char)); ###
 }
}

rewind(datfile);

countrDat = 0;
countcDat = 0;

while(fgets(dc, line, datfile) != NULL) {
 pdc = strtok(dc, "\t");
countcDat = 0;
while(pdc != NULL) {
 sscanf(pdc, "%s", dat[countrDat][countcDat]);
 ++countcDat;
 pdc = strtok(NULL, "\t");
}
++countrDat;
}

for(i=0;i<countrDat;++i) {
 for(j=0;j<countcDat;++j) {
  printf("%s\t", dat[i][j]);
 }
 printf("\n");
}

fclose(datfile);
free(dc);
for(i=0;i<countrDat;++i) {
 for(j=0;j<countcDat;++j) {
  free(dat[i][j]);
 }
}
for(i=0;i<countrDat;++i) {
 free(dat[i]);
}
free(dat);
}

valgrind сообщает о недопустимой записи размером 1 в memset ("###" - отмеченная строка). Пожалуйста, помогите выяснить, что здесь не так. После того, как "Адрес 0x0 не является ни стеками, ни malloc'ами, ни свободными" вывода valgrind, я могу исключить, что strtok отвечает за это. Это, наверное, очевидно...

1 ответ

Пожалуйста, помогите выяснить, что здесь не так. После "Адрес 0x0 не является ни стеком, ни malloc, ни свободным"

Ну, адрес пришел из malloc, а также malloc может потерпеть неудачу. Когда это терпит неудачу, это возвращает NULL, который объясняет 0x0 адрес.

Причина malloc возможно, что вы теряете память в другом месте.

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