123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169 |
- //////////////////////////////////////////////////////////////////////////////
- //
- // (C) Copyright Ion Gaztanaga 2005-2013. Distributed under the Boost
- // Software License, Version 1.0. (See accompanying file
- // LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
- //
- // See http://www.boost.org/libs/container for documentation.
- //
- //////////////////////////////////////////////////////////////////////////////
- #ifndef BOOST_CONTAINER_DETAIL_ADAPTIVE_NODE_POOL_HPP
- #define BOOST_CONTAINER_DETAIL_ADAPTIVE_NODE_POOL_HPP
- #ifndef BOOST_CONFIG_HPP
- # include <boost/config.hpp>
- #endif
- #if defined(BOOST_HAS_PRAGMA_ONCE)
- # pragma once
- #endif
- #include <boost/container/detail/config_begin.hpp>
- #include <boost/container/detail/workaround.hpp>
- #include <boost/intrusive/set.hpp>
- #include <boost/container/detail/multiallocation_chain.hpp>
- #include <boost/container/detail/pool_common_alloc.hpp>
- #include <boost/container/detail/mutex.hpp>
- #include <boost/container/detail/adaptive_node_pool_impl.hpp>
- #include <boost/container/detail/multiallocation_chain.hpp>
- #include <boost/container/detail/type_traits.hpp>
- #include <cstddef>
- #include <cmath>
- #include <cassert>
- namespace boost {
- namespace container {
- namespace dtl {
- //!Pooled memory allocator using an smart adaptive pool. Includes
- //!a reference count but the class does not delete itself, this is
- //!responsibility of user classes. Node size (NodeSize) and the number of
- //!nodes allocated per block (NodesPerBlock) are known at compile time.
- template< std::size_t NodeSize
- , std::size_t NodesPerBlock
- , std::size_t MaxFreeBlocks
- , std::size_t OverheadPercent
- >
- class private_adaptive_node_pool
- : public private_adaptive_node_pool_impl_ct
- < fake_segment_manager
- , MaxFreeBlocks
- , NodeSize
- , NodesPerBlock
- , OverheadPercent
- , unsigned(OverheadPercent == 0)*::boost::container::adaptive_pool_flag::align_only
- | ::boost::container::adaptive_pool_flag::size_ordered
- | ::boost::container::adaptive_pool_flag::address_ordered
- >
- {
- typedef private_adaptive_node_pool_impl_ct
- < fake_segment_manager
- , MaxFreeBlocks
- , NodeSize
- , NodesPerBlock
- , OverheadPercent
- , unsigned(OverheadPercent == 0)*::boost::container::adaptive_pool_flag::align_only
- | ::boost::container::adaptive_pool_flag::size_ordered
- | ::boost::container::adaptive_pool_flag::address_ordered
- > base_t;
- //Non-copyable
- private_adaptive_node_pool(const private_adaptive_node_pool &);
- private_adaptive_node_pool &operator=(const private_adaptive_node_pool &);
- public:
- static const std::size_t nodes_per_block = NodesPerBlock;
- //!Constructor. Never throws
- private_adaptive_node_pool()
- : base_t(0)
- {}
- };
- //!Pooled memory allocator using adaptive pool. Includes
- //!a reference count but the class does not delete itself, this is
- //!responsibility of user classes. Node size (NodeSize) and the number of
- //!nodes allocated per block (NodesPerBlock) are known at compile time
- template< std::size_t NodeSize
- , std::size_t NodesPerBlock
- , std::size_t MaxFreeBlocks
- , std::size_t OverheadPercent
- >
- class shared_adaptive_node_pool
- : public private_adaptive_node_pool
- <NodeSize, NodesPerBlock, MaxFreeBlocks, OverheadPercent>
- {
- private:
- typedef private_adaptive_node_pool
- <NodeSize, NodesPerBlock, MaxFreeBlocks, OverheadPercent> private_node_allocator_t;
- public:
- typedef typename private_node_allocator_t::multiallocation_chain multiallocation_chain;
- //!Constructor. Never throws
- shared_adaptive_node_pool()
- : private_node_allocator_t(){}
- //!Destructor. Deallocates all allocated blocks. Never throws
- ~shared_adaptive_node_pool()
- {}
- //!Allocates array of count elements. Can throw std::bad_alloc
- void *allocate_node()
- {
- //-----------------------
- scoped_lock<default_mutex> guard(mutex_);
- //-----------------------
- return private_node_allocator_t::allocate_node();
- }
- //!Deallocates an array pointed by ptr. Never throws
- void deallocate_node(void *ptr)
- {
- //-----------------------
- scoped_lock<default_mutex> guard(mutex_);
- //-----------------------
- private_node_allocator_t::deallocate_node(ptr);
- }
- //!Allocates a singly linked list of n nodes ending in null pointer.
- //!can throw std::bad_alloc
- void allocate_nodes(const std::size_t n, multiallocation_chain &chain)
- {
- //-----------------------
- scoped_lock<default_mutex> guard(mutex_);
- //-----------------------
- return private_node_allocator_t::allocate_nodes(n, chain);
- }
- void deallocate_nodes(multiallocation_chain &chain)
- {
- //-----------------------
- scoped_lock<default_mutex> guard(mutex_);
- //-----------------------
- private_node_allocator_t::deallocate_nodes(chain);
- }
- //!Deallocates all the free blocks of memory. Never throws
- void deallocate_free_blocks()
- {
- //-----------------------
- scoped_lock<default_mutex> guard(mutex_);
- //-----------------------
- private_node_allocator_t::deallocate_free_blocks();
- }
- private:
- default_mutex mutex_;
- };
- } //namespace dtl {
- } //namespace container {
- } //namespace boost {
- #include <boost/container/detail/config_end.hpp>
- #endif //#ifndef BOOST_CONTAINER_DETAIL_ADAPTIVE_NODE_POOL_HPP
|