linux系统编程-内存分配

1.如何调整堆的内存边界

int brk(void *end_data_segment); //参数为调整后的堆边界的地址
void *sbrk(intptr_t increment); //参数为调整的边界增量大小

**sbrk(0)**用于定位当前堆的边界地址。

2.内存分配:malloc和free

void *malloc(size_t size);
void free(void *ptr);

malloc free实现原理见c语言

3.其他分配内存的方法

void *calloc(size_t num,size_t size); //分配num个size大小的内存,分配的内存会初始化为0
void *realloc(void *ptr,size_t size); //调整ptr地址指向的内存大小
void *memalign(size_t boundary,size_t size); //分配 size 个字节的内存,起始地址是参数 boundary 的整数倍
//而 boundary必须是 2 的整数次幂。函数返回已分配内存的地址。

4.在堆栈上分配内存

void *alloca(size_t size);

优点:
a.alloca()分配内存的速度要快于 malloc()。
b.alloca()分配的内存随栈帧的移除而自动释放,亦即当调用 alloca 的函数返回之时
应用场景:
在信号处理程序中调用 longjmp()或 siglongjmp()以执行非局部跳转时,alloca()的作用尤其突出。此时,在“起跳”函数和“落地”函数之间的函数中,如果使用了 malloc()来分配内存,要想避免内存泄漏就极其困难。与之相反,alloca()完全可以避免这一问题,因为堆栈是由这些调用展开的,所以已分配的内存会被自动释放。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
内存管理机制是嵌入式系统研究中的一个重点和难点的问题,它必须满足以下几个特性: ①实时性。从实时性的角度出发,要求内存分配过程要尽可能地快。因此,在嵌入式系统中,不可能采用通用操作系统的一些复杂而完善的内存分配策略,一般没有段页式的虚存管理机制;而是采用简单、快速的内存分配方案,其分配方案也因程序对实时性的要求而异。例如,VxWorks系统采用简单的“首次适应,立即聚合”方法;VRTX中采用多个固定尺寸存储块的binning方案。 ②可靠性。嵌入式系统应用的环境千变万化,在有些特定情况下,对系统的可靠性要求极高,内存分配的请求必须得到满足,如果分配失败则可能会带来灾难性的后果。比如,飞机的燃油检测系统。在飞机飞行过程中,如果燃料发生泄漏,系统应该立即检测到,并发出相应的警报等待飞行员及时处理。如果因为内存分配失败而不能相应地操作,就可能发生机毁人亡的事故。 ③高效性。内存分配要尽可能地减少浪费。不可能为了保证满足所有的内存分配请求而将内存配置得很大。一方面,嵌入式系统对成本的要求使得内存在其中只是一种很有限的资源;另一方面,即使不考虑成本的因素,系统硬件环境有限的空间和有限的板面积决定了可配置的内存容量是很有限的。 针对以上三个约束条件,市场上主流的嵌入式操作系统,如VxWorks、嵌入式Linux 等均提出了一套有效的解决方案;但是,这些系统只提供了应用开发的接口,其底层的实现方案不可见。本文以开源的嵌入式操作系统RTEMS为例,分析了嵌入式系统内存管理所面临的问题,研究了其底层实现的解决方案。一般的嵌入式系统中最基本的内存管理方案有两种——静态分配和动态分配
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值