Ich verstehe nicht, warum in diesem Code, der Aufruf von „frei“ einen Segmentierungsfehler verursachen:Malloc, frei und Segmentierungsfehler
#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;
}
Kann es mir jemand erklären?
Danke, Segolas
haben auch einen Blick auf http://www.hpl.hp.com/personal/Hans_Boehm/gc/ Es ist sehr schön. –