¿La asignación usando sizeof produce un tamaño incorrecto para punteros de estructura?
Usando valgrind para leer esto obtengo: Escritura / lectura inválida de tamaño 4
struct Person{
char* name;
int age;
};
struct Person* create_person(char *name, int age)
{
struct Person* me = (struct Person*)malloc(sizeof(struct Person*));
assert(me!= NULL); //make sure that the statement is not null
me->name = name;
me->age = age;
return me;
}
El uso de esto consiguió un registro limpio con valgrind
struct Person{
char* name;
int age;
};
struct Person* create_person(char *name, int age)
{
struct Person* me = (struct Person*)malloc(sizeof(struct Person*)+4);
assert(me!= NULL); //make sure that the statement is not null
me->name = name;
me->age = age;
return me;
}
¿Por qué debería poner explícitamentesizeof(struct+intSize)
para evitar este error?sizeof
¿No obtienes el tamaño completo de una estructura?