目录
一、程序地址空间
在前面C语言的学习当中,我们理解的内存空间分布如下图所示:
对该内存空间分布加以说明:
1. 栈区(stack):在执行函数时,函数内局部变量的存储单元都可以在栈上创建,函数执行
结束时这些存储单元自动被释放。栈内存分配运算内置于处理器的指令集中,效率很高,但
是分配的内存容量有限。 栈区主要存放运行函数而分配的局部变量、函数参数、返回数据、
返回地址等。
2. 堆区(heap):一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收 。分配方式类似于链表。随着区域分配的进行,区域不断从低地址向高地址方向延伸。
3. 数据段(静态区)(static):存放全局变量、静态数据。程序结束后由系统释放。
4. 代码段:运行程序时,代码会加载到该位置,存放函数体(类成员函数和全局函数)的二进制代码。
通过运行如下代码,验证以下上面地址空间的分布:
1 #include<stdio.h>
2 #include<stdlib.h>
3
4 int un_init;
5 int init=10;
6
7 int main()
8 {
9 printf("code:%p\n", main);
10 // 打印正文代码区地址
11 printf("init:%p\n", &init);
12 // 初始化数据
13 printf("un_init:%p\n", &un_init);
14 // 未初始化数据
15 int *heap1 = (int*)malloc(10);
16 int *heap2 = (int*)malloc(10);
17 int *heap3 = (int*)malloc(10);
18 printf("heap1:%p\n