1 Star 0 Fork 0

mobangjack / memory

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
group__adapter.html 44.24 KB
一键复制 编辑 原始数据 按行查看 历史
Jonathan Müller 提交于 2020-05-05 17:04 . Update documentation
<!-- HTML header for doxygen 1.8.16-->
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.18"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>memory: Adapters and Wrappers</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
<tbody>
<tr style="height: 56px;">
<td id="projectalign" style="padding-left: 0.5em;">
<div id="projectname">memory
</div>
</td>
</tr>
</tbody>
</table>
</div>
<div id="main-nav">
<ul class="sm sm-dox" id="main-menu">
<li><a href="index.html">Main Page</a></li>
<li><a href="md_doc_tutorial.html">Tutorial</a></li>
<li><a href="namespacefoonathan_1_1memory.html">Index</a></li>
<li><a href="files.html">Files</a></li>
</ul>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.18 -->
</div><!-- top -->
<div class="header">
<div class="summary">
<a href="#nested-classes">Classes</a> &#124;
<a href="#typedef-members">Typedefs</a> &#124;
<a href="#func-members">Functions</a> </div>
<div class="headertitle">
<div class="title">Adapters and Wrappers</div> </div>
</div><!--header-->
<div class="contents">
<table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="nested-classes"></a>
Classes</h2></td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1aligned__allocator.html">aligned_allocator&lt; RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> adapter that ensures a minimum alignment. <a href="classfoonathan_1_1memory_1_1aligned__allocator.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1vector.html">vector&lt; T, RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Alias template for an STL container that uses a certain <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a>. <a href="classfoonathan_1_1memory_1_1vector.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structfoonathan_1_1memory_1_1forward__list__node__size.html">forward_list_node_size&lt; T &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Contains the node size of a node based STL container with a specific type. <a href="structfoonathan_1_1memory_1_1forward__list__node__size.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1allocator__deallocator.html">allocator_deallocator&lt; Type, RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A deleter class that deallocates the memory through a specified <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a>. <a href="classfoonathan_1_1memory_1_1allocator__deallocator.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1allocator__deallocator_3_01_type_0f_0e_00_01_raw_allocator_01_4.html">allocator_deallocator&lt; Type[], RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Specialization of <a class="el" href="classfoonathan_1_1memory_1_1allocator__deallocator.html">allocator_deallocator</a> for array types. <a href="classfoonathan_1_1memory_1_1allocator__deallocator_3_01_type_0f_0e_00_01_raw_allocator_01_4.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1allocator__polymorphic__deallocator.html">allocator_polymorphic_deallocator&lt; BaseType, RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A deleter class that deallocates the memory of a derived type through a specified <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a>. <a href="classfoonathan_1_1memory_1_1allocator__polymorphic__deallocator.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1allocator__deleter.html">allocator_deleter&lt; Type, RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Similar to <a class="el" href="classfoonathan_1_1memory_1_1allocator__deallocator.html">allocator_deallocator</a> but calls the destructors of the object. <a href="classfoonathan_1_1memory_1_1allocator__deleter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1allocator__deleter_3_01_type_0f_0e_00_01_raw_allocator_01_4.html">allocator_deleter&lt; Type[], RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Specialization of <a class="el" href="classfoonathan_1_1memory_1_1allocator__deleter.html">allocator_deleter</a> for array types. <a href="classfoonathan_1_1memory_1_1allocator__deleter_3_01_type_0f_0e_00_01_raw_allocator_01_4.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1allocator__polymorphic__deleter.html">allocator_polymorphic_deleter&lt; BaseType, RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Similar to <a class="el" href="classfoonathan_1_1memory_1_1allocator__polymorphic__deallocator.html">allocator_polymorphic_deallocator</a> but calls the destructors of the object. <a href="classfoonathan_1_1memory_1_1allocator__polymorphic__deleter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1fallback__allocator.html">fallback_allocator&lt; Default, Fallback &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a href="md_doc_concepts.html#raw_allocator">RawAllocator</a> with a fallback. <a href="classfoonathan_1_1memory_1_1fallback__allocator.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1growing__block__allocator.html">growing_block_allocator&lt; RawAllocator, Num, Den &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a href="md_doc_concepts.html#concept_blockallocator">BlockAllocator</a> that uses a given <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> for allocating the blocks. <a href="classfoonathan_1_1memory_1_1growing__block__allocator.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1fixed__block__allocator.html">fixed_block_allocator&lt; RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a href="md_doc_concepts.html#concept_blockallocator">BlockAllocator</a> that allows only one block allocation. <a href="classfoonathan_1_1memory_1_1fixed__block__allocator.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1memory__resource.html">memory_resource</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">The <code>memory_resource</code> abstract base class used in the implementation. <a href="classfoonathan_1_1memory_1_1memory__resource.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1memory__resource__adapter.html">memory_resource_adapter&lt; RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps a <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> and makes it a <a class="el" href="classfoonathan_1_1memory_1_1memory__resource.html">memory_resource</a>. <a href="classfoonathan_1_1memory_1_1memory__resource__adapter.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1memory__resource__allocator.html">memory_resource_allocator</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps a <a class="el" href="classfoonathan_1_1memory_1_1memory__resource.html">memory_resource</a> and makes it a <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a>. <a href="classfoonathan_1_1memory_1_1memory__resource__allocator.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structfoonathan_1_1memory_1_1is__shared__allocator_3_01memory__resource__allocator_01_4.html">is_shared_allocator&lt; memory_resource_allocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Specialization of <a class="el" href="structfoonathan_1_1memory_1_1is__shared__allocator.html">is_shared_allocator</a> to mark <a class="el" href="classfoonathan_1_1memory_1_1memory__resource__allocator.html">memory_resource_allocator</a> as shared. <a href="structfoonathan_1_1memory_1_1is__shared__allocator_3_01memory__resource__allocator_01_4.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1threshold__segregatable.html">threshold_segregatable&lt; RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a href="md_doc_concepts.html#concept_segregatable">Segregatable</a> that allocates until a maximum size. <a href="classfoonathan_1_1memory_1_1threshold__segregatable.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1binary__segregator.html">binary_segregator&lt; Segregatable, RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> that either uses the <a href="md_doc_concepts.html#concept_segregatable">Segregatable</a> or the other <code>RawAllocator</code>. <a href="classfoonathan_1_1memory_1_1binary__segregator.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1segregator.html">segregator&lt; Allocators &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Creates multiple nested <a class="el" href="classfoonathan_1_1memory_1_1binary__segregator.html">binary_segregator</a>. <a href="classfoonathan_1_1memory_1_1segregator.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1unique__ptr.html">unique_ptr&lt; T, RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <code>std::unique_ptr</code> that deletes using a <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a>. <a href="classfoonathan_1_1memory_1_1unique__ptr.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1unique__base__ptr.html">unique_base_ptr&lt; BaseType, RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <code>std::unique_ptr</code> that deletes using a <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> and allows polymorphic types. <a href="classfoonathan_1_1memory_1_1unique__base__ptr.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structfoonathan_1_1memory_1_1shared__ptr__node__size.html">shared_ptr_node_size&lt; T, StdAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Contains the node size of a node based STL container with a specific type. <a href="structfoonathan_1_1memory_1_1shared__ptr__node__size.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structfoonathan_1_1memory_1_1propagation__traits.html">propagation_traits&lt; RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Controls the propagation of a <a class="el" href="classfoonathan_1_1memory_1_1std__allocator.html">std_allocator</a> for a certain <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a>. <a href="structfoonathan_1_1memory_1_1propagation__traits.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1std__allocator.html">std_allocator&lt; T, RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">Wraps a <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> and makes it a "normal" <code>Allocator</code>. <a href="classfoonathan_1_1memory_1_1std__allocator.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1any__std__allocator.html">any_std_allocator&lt; T &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">An alias template for <a class="el" href="classfoonathan_1_1memory_1_1std__allocator.html">std_allocator</a> using a type-erased <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a>. <a href="classfoonathan_1_1memory_1_1any__std__allocator.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1tracked__block__allocator.html">tracked_block_allocator&lt; Tracker, BlockOrRawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a href="md_doc_concepts.html#concept_blockallocator">BlockAllocator</a> adapter that tracks another allocator using a <a href="md_doc_concepts.html#concept_tracker">tracker</a>. <a href="classfoonathan_1_1memory_1_1tracked__block__allocator.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1tracked__allocator.html">tracked_allocator&lt; Tracker, RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> adapter that tracks another allocator using a <a href="md_doc_concepts.html#concept_tracker">tracker</a>. <a href="classfoonathan_1_1memory_1_1tracked__allocator.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classfoonathan_1_1memory_1_1deeply__tracked__allocator.html">deeply_tracked_allocator&lt; Tracker, RawAllocator &gt;</a></td></tr>
<tr class="memdesc:"><td class="mdescLeft">&#160;</td><td class="mdescRight">A <a class="el" href="classfoonathan_1_1memory_1_1tracked__allocator.html">tracked_allocator</a> that has rebound any <a href="md_doc_concepts.html#concept_blockallocator">BlockAllocator</a> to the corresponding <a class="el" href="group__adapter.html#ga1fccf7950ead6f37a7360fe08da0ab31">deeply_tracked_block_allocator</a>. <a href="classfoonathan_1_1memory_1_1deeply__tracked__allocator.html#details">More...</a><br /></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="typedef-members"></a>
Typedefs</h2></td></tr>
<tr class="memitem:ga1fccf7950ead6f37a7360fe08da0ab31"><td class="memTemplParams" colspan="2">template&lt;class Tracker , class BlockOrRawAllocator &gt; </td></tr>
<tr class="memitem:ga1fccf7950ead6f37a7360fe08da0ab31"><td class="memTemplItemLeft" align="right" valign="top">using&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__adapter.html#ga1fccf7950ead6f37a7360fe08da0ab31">deeply_tracked_block_allocator</a> = FOONATHAN_IMPL_DEFINED(detail::deeply_tracked_block_allocator&lt; Tracker, <a class="el" href="group__core.html#gaf1ce941b1306a592d4ebba1167fd98aa">make_block_allocator_t</a>&lt; BlockOrRawAllocator &gt; &gt;)</td></tr>
<tr class="memdesc:ga1fccf7950ead6f37a7360fe08da0ab31"><td class="mdescLeft">&#160;</td><td class="mdescRight">Similar to <a class="el" href="classfoonathan_1_1memory_1_1tracked__block__allocator.html">tracked_block_allocator</a>, but shares the tracker with the higher level allocator. <a href="group__adapter.html#ga1fccf7950ead6f37a7360fe08da0ab31">More...</a><br /></td></tr>
<tr class="separator:ga1fccf7950ead6f37a7360fe08da0ab31"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="func-members"></a>
Functions</h2></td></tr>
<tr class="memitem:gae97e26711df44cb2208bc08bc3877aa8"><td class="memTemplParams" colspan="2">template&lt;typename T , class RawAllocator , typename... Args&gt; </td></tr>
<tr class="memitem:gae97e26711df44cb2208bc08bc3877aa8"><td class="memTemplItemLeft" align="right" valign="top">auto&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__adapter.html#gae97e26711df44cb2208bc08bc3877aa8">allocate_unique</a> (RawAllocator &amp;&amp;alloc, Args &amp;&amp;... args) -&gt; FOONATHAN_REQUIRES_RET(!std::is_array&lt; T &gt;::value, std::unique_ptr&lt; T, <a class="el" href="classfoonathan_1_1memory_1_1allocator__deleter.html">allocator_deleter</a>&lt; T, typename std::decay&lt; RawAllocator &gt;::type &gt;&gt;)</td></tr>
<tr class="memdesc:gae97e26711df44cb2208bc08bc3877aa8"><td class="mdescLeft">&#160;</td><td class="mdescRight">Creates a <code>std::unique_ptr</code> using a <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> for the allocation. <a href="group__adapter.html#gae97e26711df44cb2208bc08bc3877aa8">More...</a><br /></td></tr>
<tr class="separator:gae97e26711df44cb2208bc08bc3877aa8"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ga5f1df5be6a57b1ccd73cbc719487e7f8"><td class="memTemplParams" colspan="2">template&lt;typename T , class RawAllocator , typename... Args&gt; </td></tr>
<tr class="memitem:ga5f1df5be6a57b1ccd73cbc719487e7f8"><td class="memTemplItemLeft" align="right" valign="top">auto&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__adapter.html#ga5f1df5be6a57b1ccd73cbc719487e7f8">allocate_unique</a> (<a class="el" href="structfoonathan_1_1memory_1_1any__allocator.html">any_allocator</a>, RawAllocator &amp;&amp;alloc, Args &amp;&amp;... args) -&gt; FOONATHAN_REQUIRES_RET(!std::is_array&lt; T &gt;::value, std::unique_ptr&lt; T, <a class="el" href="classfoonathan_1_1memory_1_1allocator__deleter.html">allocator_deleter</a>&lt; T, <a class="el" href="structfoonathan_1_1memory_1_1any__allocator.html">any_allocator</a> &gt;&gt;)</td></tr>
<tr class="memdesc:ga5f1df5be6a57b1ccd73cbc719487e7f8"><td class="mdescLeft">&#160;</td><td class="mdescRight">Creates a <code>std::unique_ptr</code> using a type-erased <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> for the allocation. <a href="group__adapter.html#ga5f1df5be6a57b1ccd73cbc719487e7f8">More...</a><br /></td></tr>
<tr class="separator:ga5f1df5be6a57b1ccd73cbc719487e7f8"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ga2c63aa9dbdbb2e7770b565774373c18a"><td class="memTemplParams" colspan="2">template&lt;typename T , class RawAllocator &gt; </td></tr>
<tr class="memitem:ga2c63aa9dbdbb2e7770b565774373c18a"><td class="memTemplItemLeft" align="right" valign="top">auto&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__adapter.html#ga2c63aa9dbdbb2e7770b565774373c18a">allocate_unique</a> (RawAllocator &amp;&amp;alloc, std::size_t size) -&gt; FOONATHAN_REQUIRES_RET(std::is_array&lt; T &gt;::value, std::unique_ptr&lt; T, <a class="el" href="classfoonathan_1_1memory_1_1allocator__deleter.html">allocator_deleter</a>&lt; T, typename std::decay&lt; RawAllocator &gt;::type &gt;&gt;)</td></tr>
<tr class="memdesc:ga2c63aa9dbdbb2e7770b565774373c18a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Creates a <code>std::unique_ptr</code> owning an array using a <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> for the allocation. <a href="group__adapter.html#ga2c63aa9dbdbb2e7770b565774373c18a">More...</a><br /></td></tr>
<tr class="separator:ga2c63aa9dbdbb2e7770b565774373c18a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gab2f0af0321f556ec2cc36e9078928656"><td class="memTemplParams" colspan="2">template&lt;typename T , class RawAllocator &gt; </td></tr>
<tr class="memitem:gab2f0af0321f556ec2cc36e9078928656"><td class="memTemplItemLeft" align="right" valign="top">auto&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__adapter.html#gab2f0af0321f556ec2cc36e9078928656">allocate_unique</a> (<a class="el" href="structfoonathan_1_1memory_1_1any__allocator.html">any_allocator</a>, RawAllocator &amp;&amp;alloc, std::size_t size) -&gt; FOONATHAN_REQUIRES_RET(std::is_array&lt; T &gt;::value, std::unique_ptr&lt; T, <a class="el" href="classfoonathan_1_1memory_1_1allocator__deleter.html">allocator_deleter</a>&lt; T, <a class="el" href="structfoonathan_1_1memory_1_1any__allocator.html">any_allocator</a> &gt;&gt;)</td></tr>
<tr class="memdesc:gab2f0af0321f556ec2cc36e9078928656"><td class="mdescLeft">&#160;</td><td class="mdescRight">Creates a <code>std::unique_ptr</code> owning an array using a type-erased <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> for the allocation. <a href="group__adapter.html#gab2f0af0321f556ec2cc36e9078928656">More...</a><br /></td></tr>
<tr class="separator:gab2f0af0321f556ec2cc36e9078928656"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ga5becad5eeaeb066f681396d4573216ab"><td class="memTemplParams" colspan="2">template&lt;typename T , class RawAllocator , typename... Args&gt; </td></tr>
<tr class="memitem:ga5becad5eeaeb066f681396d4573216ab"><td class="memTemplItemLeft" align="right" valign="top">std::shared_ptr&lt; T &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__adapter.html#ga5becad5eeaeb066f681396d4573216ab">allocate_shared</a> (RawAllocator &amp;&amp;alloc, Args &amp;&amp;... args)</td></tr>
<tr class="memdesc:ga5becad5eeaeb066f681396d4573216ab"><td class="mdescLeft">&#160;</td><td class="mdescRight">Creates a <code>std::shared_ptr</code> using a <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> for the allocation. <a href="group__adapter.html#ga5becad5eeaeb066f681396d4573216ab">More...</a><br /></td></tr>
<tr class="separator:ga5becad5eeaeb066f681396d4573216ab"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gaf59f9fd9c834d74ce33675965cbf8e91"><td class="memTemplParams" colspan="2">template&lt;typename T , class RawAllocator , class Container = deque&lt;T, RawAllocator&gt;&gt; </td></tr>
<tr class="memitem:gaf59f9fd9c834d74ce33675965cbf8e91"><td class="memTemplItemLeft" align="right" valign="top">std::stack&lt; T, Container &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__adapter.html#gaf59f9fd9c834d74ce33675965cbf8e91">make_stack</a> (RawAllocator &amp;allocator)</td></tr>
<tr class="separator:gaf59f9fd9c834d74ce33675965cbf8e91"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:gadf0d2de1abf7d1eaf62cd9785f7b9038"><td class="memTemplParams" colspan="2">template&lt;typename T , class RawAllocator , class Container = deque&lt;T, RawAllocator&gt;&gt; </td></tr>
<tr class="memitem:gadf0d2de1abf7d1eaf62cd9785f7b9038"><td class="memTemplItemLeft" align="right" valign="top">std::queue&lt; T, Container &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__adapter.html#gadf0d2de1abf7d1eaf62cd9785f7b9038">make_queue</a> (RawAllocator &amp;allocator)</td></tr>
<tr class="separator:gadf0d2de1abf7d1eaf62cd9785f7b9038"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ga9a653f7cbdf9beea3bfed64b41f4258d"><td class="memTemplParams" colspan="2">template&lt;typename T , class RawAllocator , class Container = deque&lt;T, RawAllocator&gt;, class Compare = std::less&lt;T&gt;&gt; </td></tr>
<tr class="memitem:ga9a653f7cbdf9beea3bfed64b41f4258d"><td class="memTemplItemLeft" align="right" valign="top">std::priority_queue&lt; T, Container, Compare &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__adapter.html#ga9a653f7cbdf9beea3bfed64b41f4258d">make_priority_queue</a> (RawAllocator &amp;allocator, Compare comp={})</td></tr>
<tr class="separator:ga9a653f7cbdf9beea3bfed64b41f4258d"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
<h2 class="groupheader">Typedefs</h2>
<a id="ga1fccf7950ead6f37a7360fe08da0ab31"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ga1fccf7950ead6f37a7360fe08da0ab31">&#9670;&nbsp;</a></span>deeply_tracked_block_allocator</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">using <a class="el" href="group__adapter.html#ga1fccf7950ead6f37a7360fe08da0ab31">deeply_tracked_block_allocator</a> = FOONATHAN_IMPL_DEFINED( detail::deeply_tracked_block_allocator&lt;Tracker, <a class="el" href="group__core.html#gaf1ce941b1306a592d4ebba1167fd98aa">make_block_allocator_t</a>&lt;BlockOrRawAllocator&gt; &gt;)</td>
</tr>
</table>
</div><div class="memdoc">
<p>Similar to <a class="el" href="classfoonathan_1_1memory_1_1tracked__block__allocator.html">tracked_block_allocator</a>, but shares the tracker with the higher level allocator. </p>
<p>This allows tracking both (de-)allocations and growth with one tracker. </p><dl class="section note"><dt>Note</dt><dd>Due to implementation reasons, it cannot track growth and shrinking in the constructor/destructor of the higher level allocator. </dd></dl>
</div>
</div>
<h2 class="groupheader">Functions</h2>
<a id="gaf59f9fd9c834d74ce33675965cbf8e91"></a>
<h2 class="memtitle"><span class="permalink"><a href="#gaf59f9fd9c834d74ce33675965cbf8e91">&#9670;&nbsp;</a></span>make_stack()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::stack&lt;T, Container&gt; foonathan::memory::make_stack </td>
<td>(</td>
<td class="paramtype">RawAllocator &amp;&#160;</td>
<td class="paramname"><em>allocator</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Convenience function to create a container adapter using a certain <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a>. </p><dl class="section user"><dt>Returns:</dt><dd>An empty adapter with an implementation container using a reference to a given allocator. </dd></dl>
</div>
</div>
<a id="gae97e26711df44cb2208bc08bc3877aa8"></a>
<h2 class="memtitle"><span class="permalink"><a href="#gae97e26711df44cb2208bc08bc3877aa8">&#9670;&nbsp;</a></span>allocate_unique() <span class="overload">[1/4]</span></h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">auto foonathan::memory::allocate_unique </td>
<td>(</td>
<td class="paramtype">RawAllocator &amp;&amp;&#160;</td>
<td class="paramname"><em>alloc</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">Args &amp;&amp;...&#160;</td>
<td class="paramname"><em>args</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td> -&gt; FOONATHAN_REQUIRES_RET( !std::is_array&lt;T&gt;::value, std::unique_ptr&lt;T, <a class="el" href="classfoonathan_1_1memory_1_1allocator__deleter.html">allocator_deleter</a>&lt;T, typename std::decay&lt;RawAllocator&gt;::type&gt;&gt;)
</td>
</tr>
</table>
</div><div class="memdoc">
<p>Creates a <code>std::unique_ptr</code> using a <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> for the allocation. </p>
<dl class="section user"><dt>Effects:</dt><dd>Allocates memory for the given type using the allocator and creates a new object inside it passing the given arguments to its constructor. </dd></dl>
<dl class="section user"><dt>Returns:</dt><dd>A <code>std::unique_ptr</code> owning that memory. </dd></dl>
<dl class="section note"><dt>Note</dt><dd>If the allocator is stateful a reference to the <code>RawAllocator</code> will be stored inside the deleter, the caller has to ensure that the object lives as long as the smart pointer. </dd></dl>
</div>
</div>
<a id="ga5f1df5be6a57b1ccd73cbc719487e7f8"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ga5f1df5be6a57b1ccd73cbc719487e7f8">&#9670;&nbsp;</a></span>allocate_unique() <span class="overload">[2/4]</span></h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">auto foonathan::memory::allocate_unique </td>
<td>(</td>
<td class="paramtype"><a class="el" href="structfoonathan_1_1memory_1_1any__allocator.html">any_allocator</a>&#160;</td>
<td class="paramname">, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">RawAllocator &amp;&amp;&#160;</td>
<td class="paramname"><em>alloc</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">Args &amp;&amp;...&#160;</td>
<td class="paramname"><em>args</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td> -&gt; FOONATHAN_REQUIRES_RET(!std::is_array&lt;T&gt;::value, std::unique_ptr&lt;T, <a class="el" href="classfoonathan_1_1memory_1_1allocator__deleter.html">allocator_deleter</a>&lt;T, <a class="el" href="structfoonathan_1_1memory_1_1any__allocator.html">any_allocator</a>&gt;&gt;)
</td>
</tr>
</table>
</div><div class="memdoc">
<p>Creates a <code>std::unique_ptr</code> using a type-erased <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> for the allocation. </p>
<p>It is the same as the other overload but stores the reference to the allocator type-erased inside the <code>std::unique_ptr</code>. </p><dl class="section user"><dt>Effects:</dt><dd>Allocates memory for the given type using the allocator and creates a new object inside it passing the given arguments to its constructor. </dd></dl>
<dl class="section user"><dt>Returns:</dt><dd>A <code>std::unique_ptr</code> with a type-erased allocator reference owning that memory. </dd></dl>
<dl class="section note"><dt>Note</dt><dd>If the allocator is stateful a reference to the <code>RawAllocator</code> will be stored inside the deleter, the caller has to ensure that the object lives as long as the smart pointer. </dd></dl>
</div>
</div>
<a id="ga2c63aa9dbdbb2e7770b565774373c18a"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ga2c63aa9dbdbb2e7770b565774373c18a">&#9670;&nbsp;</a></span>allocate_unique() <span class="overload">[3/4]</span></h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">auto foonathan::memory::allocate_unique </td>
<td>(</td>
<td class="paramtype">RawAllocator &amp;&amp;&#160;</td>
<td class="paramname"><em>alloc</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">std::size_t&#160;</td>
<td class="paramname"><em>size</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td> -&gt; FOONATHAN_REQUIRES_RET( std::is_array&lt;T&gt;::value, std::unique_ptr&lt;T, <a class="el" href="classfoonathan_1_1memory_1_1allocator__deleter.html">allocator_deleter</a>&lt;T, typename std::decay&lt;RawAllocator&gt;::type&gt;&gt;)
</td>
</tr>
</table>
</div><div class="memdoc">
<p>Creates a <code>std::unique_ptr</code> owning an array using a <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> for the allocation. </p>
<dl class="section user"><dt>Effects:</dt><dd>Allocates memory for an array of given size and value initializes each element inside of it. </dd></dl>
<dl class="section user"><dt>Returns:</dt><dd>A <code>std::unique_ptr</code> owning that array. </dd></dl>
<dl class="section note"><dt>Note</dt><dd>If the allocator is stateful a reference to the <code>RawAllocator</code> will be stored inside the deleter, the caller has to ensure that the object lives as long as the smart pointer. </dd></dl>
</div>
</div>
<a id="gab2f0af0321f556ec2cc36e9078928656"></a>
<h2 class="memtitle"><span class="permalink"><a href="#gab2f0af0321f556ec2cc36e9078928656">&#9670;&nbsp;</a></span>allocate_unique() <span class="overload">[4/4]</span></h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">auto foonathan::memory::allocate_unique </td>
<td>(</td>
<td class="paramtype"><a class="el" href="structfoonathan_1_1memory_1_1any__allocator.html">any_allocator</a>&#160;</td>
<td class="paramname">, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">RawAllocator &amp;&amp;&#160;</td>
<td class="paramname"><em>alloc</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">std::size_t&#160;</td>
<td class="paramname"><em>size</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td> -&gt; FOONATHAN_REQUIRES_RET(std::is_array&lt;T&gt;::value, std::unique_ptr&lt;T, <a class="el" href="classfoonathan_1_1memory_1_1allocator__deleter.html">allocator_deleter</a>&lt;T, <a class="el" href="structfoonathan_1_1memory_1_1any__allocator.html">any_allocator</a>&gt;&gt;)
</td>
</tr>
</table>
</div><div class="memdoc">
<p>Creates a <code>std::unique_ptr</code> owning an array using a type-erased <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> for the allocation. </p>
<p>It is the same as the other overload but stores the reference to the allocator type-erased inside the <code>std::unique_ptr</code>. </p><dl class="section user"><dt>Effects:</dt><dd>Allocates memory for an array of given size and value initializes each element inside of it. </dd></dl>
<dl class="section user"><dt>Returns:</dt><dd>A <code>std::unique_ptr</code> with a type-erased allocator reference owning that array. </dd></dl>
<dl class="section note"><dt>Note</dt><dd>If the allocator is stateful a reference to the <code>RawAllocator</code> will be stored inside the deleter, the caller has to ensure that the object lives as long as the smart pointer. </dd></dl>
</div>
</div>
<a id="ga5becad5eeaeb066f681396d4573216ab"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ga5becad5eeaeb066f681396d4573216ab">&#9670;&nbsp;</a></span>allocate_shared()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::shared_ptr&lt;T&gt; foonathan::memory::allocate_shared </td>
<td>(</td>
<td class="paramtype">RawAllocator &amp;&amp;&#160;</td>
<td class="paramname"><em>alloc</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">Args &amp;&amp;...&#160;</td>
<td class="paramname"><em>args</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Creates a <code>std::shared_ptr</code> using a <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a> for the allocation. </p>
<p>It is similar to <code>std::allocate_shared</code> but uses a <code>RawAllocator</code> (and thus also supports any <code>Allocator</code>). </p><dl class="section user"><dt>Effects:</dt><dd>Calls <a class="el" href="classfoonathan_1_1memory_1_1std__allocator.html#ad4bb35bfde10edb491e593b1938f1614">std_allocator::make_std_allocator</a> to wrap the allocator and forwards to <code>std::allocate_shared</code>. </dd></dl>
<dl class="section user"><dt>Returns:</dt><dd>A <code>std::shared_ptr</code> created using <code>std::allocate_shared</code>. </dd></dl>
<dl class="section note"><dt>Note</dt><dd>If the allocator is stateful a reference to the <code>RawAllocator</code> will be stored inside the shared pointer, the caller has to ensure that the object lives as long as the smart pointer. </dd></dl>
</div>
</div>
<a id="gadf0d2de1abf7d1eaf62cd9785f7b9038"></a>
<h2 class="memtitle"><span class="permalink"><a href="#gadf0d2de1abf7d1eaf62cd9785f7b9038">&#9670;&nbsp;</a></span>make_queue()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::queue&lt;T, Container&gt; foonathan::memory::make_queue </td>
<td>(</td>
<td class="paramtype">RawAllocator &amp;&#160;</td>
<td class="paramname"><em>allocator</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p></p>
<p>Convenience function to create a container adapter using a certain <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a>. </p><dl class="section user"><dt>Returns:</dt><dd>An empty adapter with an implementation container using a reference to a given allocator. </dd></dl>
</div>
</div>
<a id="ga9a653f7cbdf9beea3bfed64b41f4258d"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ga9a653f7cbdf9beea3bfed64b41f4258d">&#9670;&nbsp;</a></span>make_priority_queue()</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::priority_queue&lt;T, Container, Compare&gt; foonathan::memory::make_priority_queue </td>
<td>(</td>
<td class="paramtype">RawAllocator &amp;&#160;</td>
<td class="paramname"><em>allocator</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">Compare&#160;</td>
<td class="paramname"><em>comp</em> = <code>{}</code>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p></p>
<p>Convenience function to create a container adapter using a certain <a href="md_doc_concepts.html#concept_rawallocator">RawAllocator</a>. </p><dl class="section user"><dt>Returns:</dt><dd>An empty adapter with an implementation container using a reference to a given allocator. </dd></dl>
</div>
</div>
</div><!-- contents -->
<!-- HTML footer for doxygen 1.8.16-->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated by &#160;<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/>
</a> 1.8.18
</small></address>
</body>
</html>
1
https://gitee.com/mobangjack/memory.git
git@gitee.com:mobangjack/memory.git
mobangjack
memory
memory
gh-pages

搜索帮助