mem_block_cache.hpp

来自「CGAL is a collaborative effort of severa」· HPP 代码 · 共 95 行

HPP
95
字号
 /* * Copyright (c) 2002 * Dr John Maddock * * Use, modification and distribution are subject to 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) * */ /*  *   LOCATION:    see http://www.boost.org for most recent version.  *   FILE         mem_block_cache.hpp  *   VERSION      see <boost/version.hpp>  *   DESCRIPTION: memory block cache used by the non-recursive matcher.  */#ifndef BOOST_REGEX_V4_MEM_BLOCK_CACHE_HPP#define BOOST_REGEX_V4_MEM_BLOCK_CACHE_HPP#include <new>#include <boost/regex/v4/regex_synch.hpp>#ifdef BOOST_HAS_ABI_HEADERS#  include BOOST_ABI_PREFIX#endifnamespace boost{namespace re_detail{struct mem_block_node{   mem_block_node* next;};struct mem_block_cache{   // this member has to be statically initialsed:   mem_block_node* next;   unsigned cached_blocks;   ~mem_block_cache()   {      while(next)      {         mem_block_node* old = next;         next = next->next;         ::operator delete(old);      }   }   void* get()   {#ifdef BOOST_HAS_THREADS      re_detail::cs_guard g(*re_detail::p_re_lock);#endif     if(next)      {         mem_block_node* result = next;         next = next->next;         --cached_blocks;         return result;      }      return ::operator new(BOOST_REGEX_BLOCKSIZE);   }   void put(void* p)   {#ifdef BOOST_HAS_THREADS      re_detail::cs_guard g(*re_detail::p_re_lock);#endif      if(cached_blocks >= BOOST_REGEX_MAX_CACHE_BLOCKS)      {         ::operator delete(p);      }      else      {         mem_block_node* old = static_cast<mem_block_node*>(p);         old->next = next;         next = old;         ++cached_blocks;      }   }};extern mem_block_cache block_cache;}} // namespace boost#ifdef BOOST_HAS_ABI_HEADERS#  include BOOST_ABI_SUFFIX#endif#endif

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?