29、深入理解内存分配机制

深入理解内存分配机制

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));

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值