您好,登錄后才能下訂單哦!
本篇內容介紹了“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內存分配是怎樣的”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。