diff options
author | Anton Samokhvalov <pg83@yandex.ru> | 2022-02-10 16:45:15 +0300 |
---|---|---|
committer | Daniil Cherednik <dcherednik@yandex-team.ru> | 2022-02-10 16:45:15 +0300 |
commit | 72cb13b4aff9bc9cf22e49251bc8fd143f82538f (patch) | |
tree | da2c34829458c7d4e74bdfbdf85dff449e9e7fb8 /util/memory/pool.cpp | |
parent | 778e51ba091dc39e7b7fcab2b9cf4dbedfb6f2b5 (diff) | |
download | ydb-72cb13b4aff9bc9cf22e49251bc8fd143f82538f.tar.gz |
Restoring authorship annotation for Anton Samokhvalov <pg83@yandex.ru>. Commit 1 of 2.
Diffstat (limited to 'util/memory/pool.cpp')
-rw-r--r-- | util/memory/pool.cpp | 76 |
1 files changed, 38 insertions, 38 deletions
diff --git a/util/memory/pool.cpp b/util/memory/pool.cpp index 9a011f0e4f..b3144aefc3 100644 --- a/util/memory/pool.cpp +++ b/util/memory/pool.cpp @@ -1,55 +1,55 @@ -#include "pool.h" - +#include "pool.h" + TMemoryPool::IGrowPolicy* TMemoryPool::TLinearGrow::Instance() noexcept { - return SingletonWithPriority<TLinearGrow, 0>(); -} - + return SingletonWithPriority<TLinearGrow, 0>(); +} + TMemoryPool::IGrowPolicy* TMemoryPool::TExpGrow::Instance() noexcept { - return SingletonWithPriority<TExpGrow, 0>(); -} - -void TMemoryPool::AddChunk(size_t hint) { - const size_t dataLen = Max(BlockSize_, hint); + return SingletonWithPriority<TExpGrow, 0>(); +} + +void TMemoryPool::AddChunk(size_t hint) { + const size_t dataLen = Max(BlockSize_, hint); size_t allocSize = dataLen + sizeof(TChunk); if (Options_.RoundUpToNextPowerOfTwo) { allocSize = FastClp2(allocSize); } TBlock nb = Alloc_->Allocate(allocSize); - + // Add previous chunk's stats if (Current_ != &Empty_) { MemoryAllocatedBeforeCurrent_ += Current_->Used(); MemoryWasteBeforeCurrent_ += Current_->Left(); } - BlockSize_ = GrowPolicy_->Next(dataLen); - Current_ = new (nb.Data) TChunk(nb.Len - sizeof(TChunk)); - Chunks_.PushBack(Current_); -} - -void TMemoryPool::DoClear(bool keepfirst) noexcept { - while (!Chunks_.Empty()) { - TChunk* c = Chunks_.PopBack(); - - if (keepfirst && Chunks_.Empty()) { - c->ResetChunk(); - Chunks_.PushBack(c); - Current_ = c; - BlockSize_ = c->BlockLength() - sizeof(TChunk); - MemoryAllocatedBeforeCurrent_ = 0; + BlockSize_ = GrowPolicy_->Next(dataLen); + Current_ = new (nb.Data) TChunk(nb.Len - sizeof(TChunk)); + Chunks_.PushBack(Current_); +} + +void TMemoryPool::DoClear(bool keepfirst) noexcept { + while (!Chunks_.Empty()) { + TChunk* c = Chunks_.PopBack(); + + if (keepfirst && Chunks_.Empty()) { + c->ResetChunk(); + Chunks_.PushBack(c); + Current_ = c; + BlockSize_ = c->BlockLength() - sizeof(TChunk); + MemoryAllocatedBeforeCurrent_ = 0; MemoryWasteBeforeCurrent_ = 0; - return; - } - - TBlock b = {c, c->BlockLength()}; - - c->~TChunk(); - Alloc_->Release(b); - } - - Current_ = &Empty_; - BlockSize_ = Origin_; + return; + } + + TBlock b = {c, c->BlockLength()}; + + c->~TChunk(); + Alloc_->Release(b); + } + + Current_ = &Empty_; + BlockSize_ = Origin_; MemoryAllocatedBeforeCurrent_ = 0; MemoryWasteBeforeCurrent_ = 0; -} +} |