线程安全的内存池 c++ 尝试(二)

mem_pool.h

#include "mempool.h"
#include <stdio.h>

//links 数组存储了内存池中所有的 存储内存块的链表;
// 因为该内存池约定内存块的大小共有17 种,分别为:
//16b,32b,64b,128b,256b,512b,1k,2k,4k,8k,16k,32k,64k,
//128k,256k,512k,1m,所以links 数组大小为17,
// 如果申请的内存块的大小超过1m,内存池不另存储,直接申请,
//直接释放;

mlink links[17];

static FILE * loginfo;

//初始化内存池;
void mempool_init()
{
 for(int i=0;i<17;i++)
 {
  //下面的操作是给每一个链表申请一个空闲的内存块,
  //该内存块是无法分配出去的,即每一个链表至少有一个
  //空闲的内存块,该内存块只是为了处理链表的添加和
  //删除时操作的方便,虽然浪费了内存,却换来了效率;
  links[i].count=1;
  links[i].phead=malloc(((unsigned int)1)<<(i+4));
  links[i].ptail=links[i].phead;
  mem_block_info * p=(mem_block_info*)links[i].phead;
  p->size=((unsigned int)1)<<(i+4);

  p->pnext=0;

  MUTEXINIT(&(links[i].head_mutex));
  MUTEXINIT(&(links[i].tail_mutex));
 }

 loginfo=fopen("mempool.txt","w+");
}

//从内存池中申请 大小为 size B 的空间;
void * mempool_malloc(unsigned int size)
{
 //实际向内存池匹配的内存块大小为size+sizeof(mem_block_info);
 unsigned int memblock_size=size+MEMBLOCKINFOSIZE;

 //因为内存块前 MEMBLOCKINFOSIZE 个字节是内存池记录
 //该内存块信息所用的,所以当返回该内存块的指针时,
 //需向后移动MEMBLOCKINFOSIZE 个字节;

 printf("mempool_malloc

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值