malloc & 内存碎片 & 细节

malloc:
在c语言中的malloc进行的动态内存分配和嵌入式系统中使用到堆区的内存分配会产生内存碎片,例如
eg1:
char *p;
if(p=char* malloc(0)==NULL){
printf(“NULL\n”);
}
else{
printf(“NOT NULL”);
}
实际上最终出现的并不是NULL,而是NOT NULL 这就说明了进行动态内存分配的时候产生了内存碎片

eg2:
char net(char **p , int num)
{
p= (char )malloc(num);
}
int main(void)
{
char *str = NULL;
net( &str , 100);
strcop(str,”hellow”);
free(str);
str=NULL;
if(str !=NULL){
strcop(str,”world”);
}
printf(“%s”,str);
}
eg2:向我们展示了malloc在函数中的使用,最终输出是world,为甚麽呢?
free在释放内存的时候,指针指向的值还是存在的,系统一般不会将释放的内存立即还给系统,所有在没有加粗部分代码的时候,仍然可以输出,当系统在释放之后又进行malloc的堆分配,就出出现意想不到的错误,所以不要尝试了吧!!!

    内部碎片的产生:因为所有的内存分配必须起始于可被 4、8 或 16 整除(视处理器体系结构而定)的地址或者因为MMU的分页机制的限制,决定内存分配算法仅能把预定大小的内存块分配给客户。假设当某个客户请求一个 43 字节的内存块时,因为没有适合大小的内存,所以它可能会获得 44字节、48字节等稍大一点的字节,因此由所需大小四舍五入而产生的多余空间就叫内部碎片。

  外部碎片的产生: 频繁的分配与回收物理页面会导致大量的、连续且小的页面块夹杂在已分配的页面中间,就会产生外部碎片。假设有一块一共有100个单位的连续空闲内存空间,范围是0~99。如果你从中申请一块内存,如10个单位,那么申请出来的内存块就为0~9区间。这时候你继续申请一块内存,比如说5个单位大,第二块得到的内存块就应该为10~14区间。如果你把第一块内存块释放,然后再申请一块大于10个单位的内存块,比如说20个单位。因为刚被释放的内存块不能满足新的请求,所以只能从15开始分配出20个单位的内存块。现在整个内存空间的状态是0~9空闲,10~14被占用,15~24被占用,25~99空闲。其中0~9就是一个内存碎片了。如果10~14一直被占用,而以后申请的空间都大于10个单位,那么0~9就永远用不上了,变成外部碎片

    所以在进行硬件换将内存比较小的外围开发的时候,一定要避免内存泄漏,合理的使用内存空间,才能更好的发挥硬件的作用
发布了34 篇原创文章 · 获赞 16 · 访问量 2万+

猜你喜欢

转载自blog.csdn.net/xuxudeta/article/details/78161510