1、栈区(stack)— 由编译器自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。
2、堆区(heap) — 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收 。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表。
例:
int a = 0; //全局初始化区
char *p1; //全局未初始化区
void main()
{
int b; //栈
char s[] = "abc"; //栈
char *p2; //栈
char *p3 = "123456"; //123456/0在常量区,p3在栈上。
static int c =0; //全局(静态)初始化区
p1 = (char *)malloc(10);
p2 = (char *)malloc(20);
//以上两个语句分配得来得10和20字节的区域就在堆区。
strcpy(p1, "123456"); //123456/0放在常量区,编译器可能会将它与p3所指向的"123456"优化成一个地方。
}
堆和栈的区别
最新推荐文章于 2025-12-05 18:30:00 发布
本文详细解析了程序运行过程中栈区与堆区的作用及管理方式。栈区由编译器自动分配释放,用于存放函数参数及局部变量;堆区则通常由程序员手动分配与释放。文章通过具体代码示例介绍了这两种存储区域的特点,并区分了它们与数据结构中栈和堆的不同。
43万+

被折叠的 条评论
为什么被折叠?



