ja nie rozumiem, dlaczego w tym kodzie, wezwanie do „wolnego” przyczyną usterki segmentacji:Malloc, wolny i segmentacja winy
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
char *char_arr_allocator(int length);
int main(int argc, char* argv[0]){
char* stringa = NULL;
stringa = char_arr_allocator(100);
printf("stringa address: %p\n", stringa); // same address as "arr"
printf("stringa: %s\n",stringa);
//free(stringa);
return 0;
}
char *char_arr_allocator(int length) {
char *arr;
arr = malloc(length*sizeof(char));
arr = "xxxxxxx";
printf("arr address: %p\n", arr); // same address as "stringa"
return arr;
}
Czy ktoś może mi to wyjaśnić?
Dzięki Segolas
Również spojrzeć na http://www.hpl.hp.com/personal/Hans_Boehm/gc/ To naprawdę miłe. –