memcached內存存储源代码与分析.doc

  1. 1、本文档共14页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
memcached內存存储源代码与分析

#define POWER_SMALLEST 1 //slabclass数组的最小下标(slabclass 主要是来保存分配好的内存) #define POWER_LARGEST 200 //slabclass数组的最大下标 #define POWER_BLOCK 1048576 //每一个chunk的最大值 #define CHUNK_ALIGN_BYTES 8 //内存对其 #define DONT_PREALLOC_SLABS //不采用事前分配内存 /* powers-of-N allocation structures */ /*管理内存的主要数据结构, 搞清楚这个数据结构对整个内存的使用,分配,释放都很重要*/ typedef struct { unsigned int size; /* sizes of items */ //该结构保存的item的size大小,即最多能保存多大的数据 unsigned int perslab; /* how many items per slab */ //分配好一个slab后,该slab可以存储多少个大小size的 void **slots; /* list of item ptrs */ //回收回来后,内存的数组 unsigned int sl_total; /* size of previous array */ //目前总共有多少个空余的内存块 unsigned int sl_curr; /* first free slot */ //目前已经使用到了多少个内存块 void *end_page_ptr; /* pointer to next free item at end of page, or 0 */ //每个slab中,可使用的地址 unsigned int end_page_free; /* number of items remaining at end of last alloced page */ //该slab中,可使用的内存块大小 unsigned int slabs; /* how many slabs were allocated for this class */ //已经使用slab void **slab_list; /* array of slab pointers */ //保存每个slab的起始地址 unsigned int list_size; /* size of prev array */ //总共有多少个slab unsigned int killing; /* index+1 of dying slab, or zero if none */ } slabclass_t; static slabclass_t slabclass[POWER_LARGEST + 1]; //核心的slabclass变量, 保存所有的内存 static size_t mem_limit = 0; //限制memcache内存的使用的大小 static size_t mem_malloced = 0; //已经创建使用的内存大小 static int power_largest; //使用中的slabclass的最大值 static void *mem_base = NULL; //创建内存的起始值 static void *mem_current = NULL; //当前使用内存的地址 static size_t mem_avail = 0; //可以使用的内存大小 /* * F

文档评论(0)

fv45ffsjjI + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档