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