SGI STL 第二级空间配置器函数 allocate()

4 篇文章 0 订阅

__default_alloc_template拥有配置器的标准接口函数allocate()。

        此函数首先判断区块大小:

        如果大于128bytes,就调用第一级配置器;

        如果小于128bytes,就检查对应的free lists。

        1.如果free list 之内有可用的区块,就直接拿来用;

        2.如果没有,就将区块大小上调至8倍数边界,然后调用refill()准备为free list重新填充空间。

static void * allocate(size_t n)
{
   obj * volatile * my_free_list;
   obj * result ;
   //大于128bytes,使用第一级空间配置器
   if(n > (size_t)__MAX_BYTES) //__MAX_BYTES ==128
         return (malloc_alloc::allocate(n));
   //小于128 ,则在16个free lists中选择适当的一个
   my_free_list = free_list +FREELIST_INDEX(n);
   result = *my_free_list ;
   if(result ==0)//不存在
   {
        void * r = refill(round_up(n)) ;//填充free list
        return r ;//返回给用户
   }
   //调整free list
   *my_free_list = result->free_list_link ;
   return result ;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值