本篇内容介绍了“redis内存分配是怎样的”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
redis内存管理是对malloc系列函数做了封装。额外记录了申请的内存大小信息。
#include <stdlib.h>#include <string.h>static size_t used_memory = 0;/* 分配sizeof(size_t)+size大小的内存,前面sizeof(size_t)个字节记录本次分配的大小, 记录分配的总内存大小,返回用于存储数据的内存首地址,即跨过sizeof(size_t)大小个字节*/void *zmalloc(size_t size) { void *ptr = malloc(size+sizeof(size_t)); if (!ptr) return NULL; *((size_t*)ptr) = size; used_memory += size+sizeof(size_t); return (char*)ptr+sizeof(size_t);}// 重新分配内存,ptr是旧数据的内存首地址,size是本次需要分片的内存大小void *zrealloc(void *ptr, size_t size) { void *realptr; size_t oldsize; void *newptr; // ptr为空即没有旧数据,新申请一块内存即可,不涉及数据迁移 if (ptr == NULL) return zmalloc(size); // 旧数据占据的内存大小 realptr = (char*)ptr-sizeof(size_t); // 得到数据部分的内存大小 oldsize = *((size_t*)realptr); // 以旧数据的内存地址为基地址,重新分配size+sizeof(size_t)大小的内存 newptr = realloc(realptr,size+sizeof(size_t)); if (!newptr) return NULL; // 记录数据部分的内存大小 *((size_t*)newptr) = size; // 重新计算已分配内存的总大小,sizeof(size_t)这块内存仍然在使用,不需要计算 used_memory -= oldsize; used_memory += size; // 返回存储数据的内存首地址 return (char*)newptr+sizeof(size_t);}void zfree(void *ptr) { void *realptr; size_t oldsize; if (ptr == NULL) return; // 算出真正的内存首地址 realptr = (char*)ptr-sizeof(size_t); oldsize = *((size_t*)realptr); // 减去释放的内存大小 used_memory -= oldsize+sizeof(size_t); free(realptr);}// 复制字符串char *zstrdup(const char *s) { size_t l = strlen(s)+1; char *p = zmalloc(l); memcpy(p,s,l); return p;}size_t zmalloc_used_memory(void) { return used_memory;}
“redis内存分配是怎样的”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://my.oschina.net/u/4217331/blog/4378828