¿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?

Respuestas a la pregunta(2)

Su respuesta a la pregunta