您好,登錄后才能下訂單哦!
代碼參考leveldb實現內存池的方法,由于實際工作中暫時未用到過內存池,因此這里只是一個簡單的內存池實現,后續有需要時,可以根據實際需求再對代碼進行修改。
arena.h
#ifndef ARENA_H #define ARENA_H #include <stdio.h> #include <vector> #include <stdint.h> #include <assert.h> //內存池類 //析構函數中自動釋放內存 class Arena { public: Arena(); ~Arena(); //內存申請函數 //@bytes 需要申請的內存大小 //返回指向內存的指針 char* Allocate(size_t bytes); //內存使用情況函數 size_t MemoryUsage() const { return memory_usage_; } size_t MemoryRemain() { return alloc_bytes_remaining_; } private: //申請內存函數,當內存池中剩余內存少于申請內存時使用 //@bytes 需要申請的內存大小 //返回指向內存的指針 char* AllocateFallback(size_t bytes); //申請塊內存函數,直接申請一塊新的內存塊 //@block_bytes 需要申請的塊內存大小 //返回指向內存的指針 char* AllocateNewBlock(size_t block_bytes); char* alloc_ptr_; //指向內存的指針 size_t alloc_bytes_remaining_; //剩余可用內存大小 std::vector<char*> blocks_; //內存池 size_t memory_usage_; //總共申請的內存大小 Arena(const Arena&); void operator=(const Arena&); }; inline char* Arena::Allocate(size_t bytes) { assert(bytes > 0); if(bytes <= alloc_bytes_remaining_) { char* result = alloc_ptr_; alloc_ptr_ += bytes; alloc_bytes_remaining_ -= bytes; return result; } return AllocateFallback(bytes); } #endif // ARENA_H
arena.cpp
#include "arena.h" #include <assert.h> //固定塊內存大小 static const int kBlockSize = 4096; Arena::Arena() : memory_usage_(0) { alloc_ptr_ = NULL; alloc_bytes_remaining_ = 0; } Arena::~Arena() { for(size_t i = 0; i < blocks_.size(); i++) delete[] blocks_[i]; } char* Arena::AllocateFallback(size_t bytes) { if(bytes > kBlockSize/4) { char* result = AllocateNewBlock(bytes); return result; } alloc_ptr_ = AllocateNewBlock(kBlockSize); alloc_bytes_remaining_ = kBlockSize; char* result = alloc_ptr_; alloc_ptr_ += bytes; alloc_bytes_remaining_ -= bytes; return result; } char* Arena::AllocateNewBlock(size_t block_bytes) { char* result = new char[block_bytes]; blocks_.push_back(result); memory_usage_ = MemoryUsage() + block_bytes + sizeof(char*); return result; }
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。