深入理解内存分配机制
1. 基础内存分配函数
在Unix系统中,有两个与内存分配相关的函数 brk 和 sbrk ,它们源自早期的Unix系统,当时堆和栈处于同一内存段。动态内存分配在堆中从段的底部向上增长,而栈从段的顶部向下向堆增长,两者的分界线被称为“断点”(break point)。在现代系统中,数据段有自己的内存映射,我们仍然将映射的结束地址称为断点。
#include <unistd.h>
int brk (void *end);
void * sbrk (intptr_t increment);
-
brk函数:将断点(数据段的结束地址)设置为end指定的地址。成功时返回 0,失败时返回 -1,并将errno设置为ENOMEM。 -
sbrk函数:将数据段的结束地址增加increment,increment可以是正或负的增量。该函数返回修订后的断点。例如,increment为 0 时可以打印当前断点:
printf ("The current break point is %p\n", sbrk (0));
超级会员免费看
订阅专栏 解锁全文

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



