前言
按照https://www.zhihu.com/question/28677076中的推荐,从今天起开始Redis源码的阅读工作,第一步便是Redis的内存分配机制。代码都在zmalloc.h和zmalloc.c中。
头文件
接下来就是一步一步解读zmalloc.h,首先第一个
#define __xstr(s) __str(s)
#define __str(s) #s
第二行中似乎有点奇怪,这个#s实际上就是在预处理阶段将s转换成字符串,s如果是1234,则__str(s)的结果就是"1234"。下面的:
#if defined(USE_TCMALLOC)
#elif defined(USE_JEMALLOC)
这一部分是用来判断是否使用tcmalloc或者jemalloc作为内存分配器
源码
zmalloc
正如其名,最关键的可能就是zmalloc函数,代码为
void *zmalloc(size_t size) {
void *ptr = ztrymalloc_usable(size, NULL);
if (!ptr) zmalloc_oom_handler(size);
return ptr;
}
先看调用的第一个函数ztrymalloc_usable:
void *ztrymalloc_usable(size_t size, size_t *usable) {
ASSERT_NO_SIZE_OVERFLOW(size);//断言size是否溢出
void *ptr = malloc(MALLOC_MIN_SIZE(size)+PREFIX_SIZE);
if (!ptr) return NULL;
这个函数第一行ASSERT_NO_SIZE_OVERFLOW是用来断言size是否溢出,通过