Por que o malloc (sizeof (pointer)) funciona?

Este código a seguir funciona bem:

#include <stdio.h>
#include <stdlib.h>

int main()
{
    struct node{
        int a, b, c, d, e;
    };
    struct node *ptr = NULL;
    printf("Size of pointer ptr is %lu bytes\n",sizeof (ptr));
    printf("Size of struct node is %lu bytes\n",sizeof (struct node));
    ptr = (struct node*)malloc(sizeof (ptr));               //Line 1
//    ptr = (struct node*)malloc(sizeof (struct node));    //Line 2

    ptr->a = 1; ptr->b = 2; ptr->c = 3; ptr->d = 4; ptr->e = 5;
    printf("a: %d, b: %d, c: %d, d: %d, e: %d\n",
            ptr->a,ptr->b,ptr->c,ptr->d,ptr->e);
    return 0;
}

Quando cumprida como:

gcc -Wall file.c

Minha pergunta é: por que isso está bem?

malloc aloca o número de bytes especificados em seu argumento. Aquisizeof ptr é 8 bytes na minha máquina linux de 64 bits. eu penseimalloc irá fornecer 8 bytes, mas, então, como está acessando todas as variáveis ​​a, b, c, d, e? É com apenas gcc ou estou faltando alguma coisa com o padrão C?

Tanto quanto eu sei "Linha 2" deve estar lá em vez de "Linha 1", mas qualquer uma das linhas funciona bem. Por quê?

questionAnswers(4)

yourAnswerToTheQuestion