brk()和sbrk()函数的使用

根据上一篇文章继续解释

brksbrk的定义

  在man手册中定义了这两个函数:

 

1 #include <unistd.h>
2 int brk(void *addr);
3 void *sbrk(intptr_t increment);

 

  手册上说brksbrk会改变program break的位置,program break被定义为程序data segment的结束位置。感觉这句话不是很好理解,从下面程序地址空间的分布来看,data segment后面还有bss segment,显然和手册说的不太一样。一种可能的解释就是手册中的data segment和下图中的data segment不是一个意思,手册中的data segment应该包含了下图中的data segmentbss segmentheap,所以program break指的就是下图中heap的结束地址。

 

  有了前面program break的概念后,我们来看下brksbrk的作用。brk通过传递的addr来重新设置program break,成功则返回0,否则返回-1。而sbrk用来增加heap,增加的大小通过参数increment决定,返回增加大小前的heapprogram break如果increment为0则返回program break

  从上面的图可以看出heap的起始地址并不是bss segment的结束地址,而是随机分配的,下面我们用一个程序来验证下:

 

复制代码
 1 #include <stdio.h>
 2 #include <unistd.
  • 5
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`malloc`函数是C语言中用于动态内存分配的重要函数,其底层实现涉及到操作系统、内存管理、以及C语言本身的内存管理机制等多个方面。一般来说,`malloc`函数会调用操作系统提供的内存分配函数(如Linux下的`brk`或`sbrk`,Windows下的`VirtualAlloc`等),具体实现可能会因操作系统和编译器而异。 在底层实现上,`malloc`通常会遵循以下步骤: 1. **初始化堆栈**:初始化一个用于存储分配大小的内部数据结构,以及用于跟踪未分配空间的链表。 2. **请求内存**:调用操作系统提供的内存分配函数(如上面提到的`brk`或`sbrk`),请求指定大小的内存。 3. **检查内存分配**:如果请求的内存成功分配,那么返回一个指向这块内存的指针;否则,返回NULL,表示内存分配失败。 4. **清理**:在释放内存之前,可能会对已分配的内存进行一些清理工作(如将未使用的内存标记为可重用)。 注意,`malloc`的实现通常比较复杂,而且会涉及到许多底层的细节。此外,由于不同的操作系统和编译器可能有不同的实现方式,因此具体的实现可能会有所不同。如果你对`malloc`的实现有更深入的兴趣,我建议你查阅相关的文档和资料,或者直接查看你所使用的操作系统的源代码。 最后,请注意,动态内存分配(如使用`malloc`)可能会导致内存碎片问题,因此在需要大量分配和释放内存的情况下,可能需要考虑使用更高级的内存管理策略,如内存池或双端队列等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值