C语言中内存动态分配应注意的问题

最近在校给老师做项目,写一个Linux下上位机的C语言程序,由于上位机内存有限,所以临时字符串都用malloc进行动态分配,然后再用free对内存进行释放。刚开始写的过程中对数据栈没有过多考虑导致了程序接二连三的出错。在此将经验写下,以防日后忘记。

char *line;

char *buf;

FILE *fp;

buf = malloc(MAXLEN);

line = malloc(MAXLINE);

fp = fopen("test", "r");

while(fgets(line, MAXLINE, fp) != NULL)

{

strcat(buf, line);

}

fclose(fp);

...

...

free(line);

free(buf);


 
这段程序有两个地方可能出错: 

1、fgets(line, MAXLINE, fp)  :由于我们是先对字符串line进行内存分配,然后再对buf进行分配。Linux下一般使用从低向高分配,所以buf到line之间只有MAXLEN个字节,而执行strcat(buf,line)函数,会使buf的内存增大,当buf内存大于MAXLEN时将抢占了line的内存,因此执行fgets(line,MAXLINE,fp)时就会出错。

2、free(buf):刚开始以为将buf和line分配内存的顺序颠倒下buf内存就可以不受限制的增长了,可是当执行free(buf)时,由于buf刚开始分配的内存只有MAXLEN,而现在其内存已经超过了MAXLEN,所以释放时会出错。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值