最简单的malloc free函数实现(用于arms3c2440)

  1. extern "C" void *malloc(unsigned nbyte) 
  2. {
  3.     static int* begin = (int *)Image$$RW$$Limit;                                //堆首地址
  4.     static int* end = (int *)(HEAPEND);                                         //堆大小
  5.     static int* top = begin;                                                    //堆顶
  6.     int* cur = begin;
  7.     int size = ((nbyte%4 == 0) ? nbyte/4 : nbyte/4+1);                          //尺寸对齐
  8.     
  9.     
  10.     while(cur < top)                                                            //查找空闲块
  11.     {
  12.         if(*cur == 0 && *(cur+1) == size)                                           //如果找到同样尺寸的空闲块
  13.         {
  14.             *cur = 1;                                                               //置占用位
  15.             return (cur+2);                                                         //返回地址
  16.         }
  17.         else
  18.         {
  19.             cur += 2 + *(cur+1);                                                    //遍历至下一个有效位
  20.         }
  21.     }
  22.     
  23.     *top++ = 1;                                                             //分配新块
  24.     *top++ = size;
  25.     cur = top;
  26.     top += size;                                                                
  27.     if(top >= end)
  28.     {
  29.         top -= size+2;
  30.         return NULL;
  31.     }
  32.     else
  33.     {
  34.         return cur;
  35.     }
  36. }
  37. //-------------------------------------------------------------------
  38. extern "C" void free(void *pt)
  39. {
  40.     int *cur = (int *)pt;
  41.     *(cur-2) = 0;
  42. }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

子正

thanks, bro...

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值