You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
68 lines
1.8 KiB
68 lines
1.8 KiB
// Copyright (c) 2011 The LevelDB Authors. All rights reserved. |
|
// Use of this source code is governed by a BSD-style license that can be |
|
// found in the LICENSE file. See the AUTHORS file for names of contributors. |
|
|
|
#ifndef STORAGE_LEVELDB_UTIL_ARENA_H_ |
|
#define STORAGE_LEVELDB_UTIL_ARENA_H_ |
|
|
|
#include <cstddef> |
|
#include <vector> |
|
#include <assert.h> |
|
#include <stdint.h> |
|
|
|
namespace leveldb { |
|
|
|
class Arena { |
|
public: |
|
Arena(); |
|
~Arena(); |
|
|
|
// Return a pointer to a newly allocated memory block of "bytes" bytes. |
|
char* Allocate(size_t bytes); |
|
|
|
// Allocate memory with the normal alignment guarantees provided by malloc |
|
char* AllocateAligned(size_t bytes); |
|
|
|
// Returns an estimate of the total memory usage of data allocated |
|
// by the arena (including space allocated but not yet used for user |
|
// allocations). |
|
size_t MemoryUsage() const { |
|
return blocks_memory_ + blocks_.capacity() * sizeof(char*); |
|
} |
|
|
|
private: |
|
char* AllocateFallback(size_t bytes); |
|
char* AllocateNewBlock(size_t block_bytes); |
|
|
|
// Allocation state |
|
char* alloc_ptr_; |
|
size_t alloc_bytes_remaining_; |
|
|
|
// Array of new[] allocated memory blocks |
|
std::vector<char*> blocks_; |
|
|
|
// Bytes of memory in blocks allocated so far |
|
size_t blocks_memory_; |
|
|
|
// No copying allowed |
|
Arena(const Arena&); |
|
void operator=(const Arena&); |
|
}; |
|
|
|
inline char* Arena::Allocate(size_t bytes) { |
|
// The semantics of what to return are a bit messy if we allow |
|
// 0-byte allocations, so we disallow them here (we don't need |
|
// them for our internal use). |
|
assert(bytes > 0); |
|
if (bytes <= alloc_bytes_remaining_) { |
|
char* result = alloc_ptr_; |
|
alloc_ptr_ += bytes; |
|
alloc_bytes_remaining_ -= bytes; |
|
return result; |
|
} |
|
return AllocateFallback(bytes); |
|
} |
|
|
|
} // namespace leveldb |
|
|
|
#endif // STORAGE_LEVELDB_UTIL_ARENA_H_
|
|
|