malloc()函数和free()函数源代码

来源:互联网 发布:备考注册会计师 知乎 编辑:程序博客网 时间:2024/05/21 11:33

         虽然malloc()函数和free()函数是C语言中最常用的函数之一,但是可能大多数人只是用它,却没有去查看它的原型。记得有一次听一个学长说他去面试,面试官让他写出malloc()函数的原型,他当时不知所措就悲剧了。今天看了一篇文章,给出了malloc()函数的源代码,特转载于此与大家共享。

原文地址:http://blog.sina.com.cn/s/blog_642bb6110100k144.html

        该实现使用大容量的静态数组作为堆,但也可使用操作系统调用分配堆。定义了一个数据类型Header保存每个存储器块的簿记信息,定义了具有Header类型元素的堆数组,这样就可以很容易地将簿记信息保存在存储器块中。类型Header包含了3块信息:指向列表的下一个块的指针,当前分配空间的长度,后面的自由空间的长度。另外,类型Header的定义还使用了一个union声明和Align数据类型,这是将存储器元素排在合理的字节边界上,根据系统的不同,这有时是需要的,有时是不需要的。

        在malloc函数中,当申请空间时,至少要分配两个Header元素节点,有什么原因吗?当然有,因为每个空间块都包含两部分:空间头和空间体。空间头是为维护堆而设计的,说到底就是维护已用空间链表,为搜索空闲空间和释放已用空间服务。空间体是供用户读写的,当malloc函数返回给用户一个指针时,用户就可以设定自己的规格,比如强制转换成int或double类型,接下来就可以按照这种规格进行读写了。需要注意一点,空间头是不能被用户访问的,它是用来维护堆的,不是为用户服务的,所以malloc函数返回的指针是指向空间体的,而不是指向空间头的,理所当然free函数得到的指针也是指向空间体的。可是为了释放空间,free函数需要得到该空间的空间头信息,所以实现时需要把指针调整一下,改为指向空间头,此情形下,减一即可。另外一点,空间头和空间体同为Header类型,用union声明再合适不过。下面就是malloc函数和free函数的实现代码:



 

#define NULL 0#define MEMSEZE 8096typedef double Align;typedef union header{        struct {               union header* next;               unsigned usedsize;               unsigned freesize;               }s;        Align a;}header;static Header mem[MEMSIZE];static Header* memptr=NULL;void* malloc(unsigned nbytes){      Header *p,*newp;      unsigned nunits;      nunits=(nbytes+sizeof(Header)-1)/sizeof(Header)+1;      if(memptr==NULL)      {         memptr->s.next=memptr=mem;         memptr->s.usedsize=1;         memptr->s.freesize=MEMSIZE-1;      }      for(p=memptr;(p->s.next!=memptr) && (p->s.freesize<nunits);p=p->s.next);      if(p->freesize<nunits) return NULL;      newp=p+p->s.usedsize;      newp->s.usedsize=nunits;      newp->s.freesize=p->s.freesize-nunits;      newp->s.next=p->s.next;      p->s.freesize=0;      p->s.next=newp;      memptr=newp;      return (void*)(newp+1);}void free(void* ap){     Header *bp,*p,*prev;     bp=(Header*)ap-1;     for(prev=memptr,p=memptr->s.next;     (p!=bp) && (p!=memptr);prev=p,p=p->next);     if(p!=bp) return;     prev->s.freesize+=p->s.usedsize+p->s.freesize;     prev->s.next=p->s.next;     memptr=prev;}
0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 手机老年机突然黑屏开不了机怎么办 苹果7P遮挡传感器就黑屏怎么办 手机被偷支付宝的钱被偷怎么办 oppo手机微信视频黑屏了怎么办 小米账号锁死插卡不显示卡怎么办 红米手机充电时不黑屏怎么办 酷派手机开机出现系统错误怎么办 乐视1s手机开不了机怎么办 酷派手机的信息文件夹不见了怎么办 酷派手机开机卡在开机界面怎么办 魅蓝拨号键老是闪退怎么办 手机上浏览器搜索时字在右边怎么办 酷比魔方平板开不开机怎么办 红米手机摔了有一角黑屏了怎么办 红米手机刷机黑屏打不开怎么办 魅蓝x一打电话就黑屏怎么办 红米手机黑屏打不开怎么办充电发烫 小米手机打电话来是关机的怎么办 红米手机打电话自动灭屏怎么办 红米5s手机白屏怎么办 红米手机黑屏开不了机怎么办 红米note开机键不灵了怎么办 红米2忘记锁屏密码怎么办 红米1手机忘记锁屏密码怎么办 红米4x关不了机怎么办 红米4a手机屏幕黑屏打不开怎么办 红米手机为什么开不了机怎么办 红米note手机刷机失败怎么办 金立手机来电屏幕不亮怎么办 小米5s桌面相机图标不见了怎么办 小米手机锁屏密码忘了怎么办? 小米平板电脑锁屏密码忘了怎么办 小米手机进水了黑屏了嗡嗡响怎么办 华为诺娃2手机声音小怎么办 华为平板锁屏密码忘记了怎么办 华为麦芒6手机按键摔坏了怎么办 定频空调加错了佛里昂怎么办 定频空调外机噪音大怎么办 老美的定频空调出现p0怎么办 华为揽阅m2青春版卡顿了怎么办 华为揽阅M2青春版发热卡顿怎么办