从编译原理上来说,声明是仅仅告诉编译器,有个某类型的变量会被使用,但是编译器并不会为它分配任何内存。而定义就是分配了内存。
对于下面的两句代码:
void Func()
{
int a;
int b=1;
a=0;
}
对于第一行代码,编译器不会做任何事,它不会为它在栈中分配一点东西,直到第三句,a=0;时,编译器才会将其压入栈中。而对于int b=0;这一句,编译器就会生成一条指令,为它赋值。
同理,对于结构体也是如此。如对于链表,在 struct ListNode* N后,需要malloc分配内存才能完成初始化
2017.12.2 更新:
注意,在完成对变量(包括指针变量)的声明时,编译器将为其分配地址!
如:
int r;
printf("&r = %p\n", &r);
仍然可以得到r的地址
对于指针:
int* p;
int x = 3;
printf("&p=%p\n", &p);
p = &x;
printf("p=%p\n", p);
printf("&p=%p\n", &p);
可以仍然可以得到其地址。而且貌似系统喜欢将存放的地址放在指针指向的地址之后?