单链表定义时的一个小问题

想问一个一直以来忽视的很基础性的问题。

严版数据结构中对于链表的定义是这样的:
typedef struct LNode{
Elemtype data;
struct LNode *next;
}LNode, *LinkList;

请问以下两个语句的区别在哪里?

LNode *p;

p = (LinkList)malloc(sizeof(LNode));

我以为这都是定义了一个结点,并将指针指向了这个借点空间,但无法区分两者的真正区别,比如定义、用法、场合

LNode *p;这一句只是声明了一个结构体指针变量,这个变量没有内存空间

p = (LinkList)malloc(sizeof(LNode));这一句是为指针变量分配内存空间,只有分配了内存空间,这个变量才能使用