2015-12-08 04:51:55 +08:00
|
|
|
#pragma once
|
2015-10-09 07:24:12 +08:00
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include "utils/auto_scope.hpp"
|
|
|
|
|
|
|
|
template <size_t block_size>
|
|
|
|
class BlockAllocator
|
|
|
|
{
|
|
|
|
struct Block
|
|
|
|
{
|
|
|
|
Block()
|
|
|
|
{
|
|
|
|
data = malloc(block_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
Block(void* ptr)
|
|
|
|
{
|
|
|
|
data = ptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
void* data;
|
|
|
|
};
|
|
|
|
|
|
|
|
public:
|
|
|
|
static constexpr size_t size = block_size;
|
|
|
|
|
|
|
|
BlockAllocator(size_t capacity = 0)
|
|
|
|
{
|
|
|
|
for(size_t i = 0; i < capacity; ++i)
|
|
|
|
blocks.emplace_back();
|
|
|
|
}
|
|
|
|
|
|
|
|
void* acquire()
|
|
|
|
{
|
|
|
|
if(blocks.size() == 0)
|
|
|
|
blocks.emplace_back();
|
|
|
|
|
|
|
|
Auto(blocks.pop_back());
|
|
|
|
return blocks.back().data;
|
|
|
|
}
|
|
|
|
|
|
|
|
void release(void* ptr)
|
|
|
|
{
|
|
|
|
blocks.emplace_back(ptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
std::vector<Block> blocks;
|
|
|
|
};
|