linux学习—内存管理(虚拟内存的分配与释放)
sbrk函数
【 #include <unistd.h>
void* sbrk(intptr_t increment);
功能:以相对方式分配和释放虚拟内存
参数:increment 堆内存的字节增量(以字节为单位)
>0 - 分配内存
<0 - 释放内存
=0 - 当前堆尾
返回值:成功返回调用该函数前的堆尾指针,失败返回-1。】
系统内部维护了一个指针,指向当前尾椎,即堆区最后一个字节的下一个位置,sbrk函数根据增量参数调整该指针的位置,同时返回该指针在调整前的位置,期间若发现内存页耗尽或空闲,则自动追加或取消内存页的映射
brk函数
【 #include <unistd.h>
int brk(void* end_data_segment);
功能:以绝对方式分配和释放虚拟内存
参数:end_data_segment 堆尾指针的目标位置
> 堆尾指针的原位置 - 分配内存
< 堆尾指针的原位置 - 释放内存
= 堆尾指针的原位置 - 空操作
返回值:成功返回0,失败返回-1。】
系统内部维护一个指针,指向当前堆尾,即堆区最后一个字节的下一个位置,brk函数根据指针参数设置该指针的位置,其间若发现内存页耗尽或空闲,则自动追加或取消内存页的映射
1)、事实上,sbrk和brk不过是移动堆尾指针的两种不同方法,移动过程中还要兼顾虚拟内存和物理内存之间映射关系的建立和解除(以页为单位)
2)、用sbrk分配内存比较方便,用多少内存就传多少增量参数,同时返回指向新分配内存区域的指针,但用sbrk做一次性内存释放比较麻烦,因为必须将所有的既往增量进行累加
3)、用brk释放内存比较方便,只需将堆尾指针设回到一开始的位置即可一次性释放掉之前分多次分配的内存,但用brk分配内存比较麻烦,因为必须根据所需要的内存大小计算出堆尾指针的绝对位置
4)、用sbrk分多次分配适量内存,最后用brk一次性整体释放