小甲鱼 P39 C语言的内存布局规律 代码段 数据段 bss段 堆 栈
小甲鱼 P39 C语言的内存布局规律
代码段(Text segment):
通常是指用来存放程序执行代码的一块内存区域。
数据段:(Initialized data segment):
通常用来存放已经初始化的全局变量和局部静态变量
BSS段:
通常是指用来存放程序中未初始化的全局变量的一块内存区域。
#include <stdio.h>
int global_uuinit_var;//bss段
int global_uuinit_var1 = 520;//数据段
int main(void)
{
static int num;//bss段
static int num1 = 1;//数据段
char *str = "hello world";//代码段
return 0;
}
堆
堆是用于存放进程运行中被动态分配的内存段,它的大小并不固定,可动态扩展或缩小。当进程调用malloc等函数分配内存时,新分配的内存就被动态添加到堆上;当利用free等函数释放内存时,被释放的内存从堆中被剔除。
栈
堆栈。栈是函数执行的内存区域,通常和堆共享同一片区域。
栈和堆的区别
申请方式:
堆有程序员手动申请
栈由系统自动分配
释放方式:
堆由程序员手动释放
栈由系统自动释放
生存周期:
堆的生存周期由动态申请到程序员主动释放为止,不同函数之间均可自由访问
栈的生存周期由函数调用开始到函数返回时结束,函数之间的局部变量不能互相访问
#include <stdio.h>
#include <stdlib.h>
int *func(void)
{
int *ptr = NULL;
ptr = (int *)malloc(sizeof(int));//堆
if (ptr == NULL)
{
exit(1);
}
*ptr = 520;
return ptr;
}
int main(void)
{
int *ptr= NULL;
ptr = func();
printf("%d\n", *ptr);
free(ptr);
return 0;
}
发展方向:
堆:从低地址向高地址发展
栈:由高地址向低地址发展