• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1<html>
2<head>
3<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
4<title>Class template simple_segregated_storage</title>
5<link rel="stylesheet" href="../../../../../doc/src/boostbook.css" type="text/css">
6<meta name="generator" content="DocBook XSL Stylesheets V1.79.1">
7<link rel="home" href="../index.html" title="Boost.Pool">
8<link rel="up" href="../header/boost/pool/simple_segregated_storage_hpp.html" title="Header &lt;boost/pool/simple_segregated_storage.hpp&gt;">
9<link rel="prev" href="../header/boost/pool/simple_segregated_storage_hpp.html" title="Header &lt;boost/pool/simple_segregated_storage.hpp&gt;">
10<link rel="next" href="../BOOST_POOL_VALIDATE_INTERNALS.html" title="Macro BOOST_POOL_VALIDATE_INTERNALS">
11</head>
12<body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF">
13<table cellpadding="2" width="100%"><tr>
14<td valign="top"><img alt="Boost C++ Libraries" width="277" height="86" src="../../../../../boost.png"></td>
15<td align="center"><a href="../../../../../index.html">Home</a></td>
16<td align="center"><a href="../../../../../libs/libraries.htm">Libraries</a></td>
17<td align="center"><a href="http://www.boost.org/users/people.html">People</a></td>
18<td align="center"><a href="http://www.boost.org/users/faq.html">FAQ</a></td>
19<td align="center"><a href="../../../../../more/index.htm">More</a></td>
20</tr></table>
21<hr>
22<div class="spirit-nav">
23<a accesskey="p" href="../header/boost/pool/simple_segregated_storage_hpp.html"><img src="../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../header/boost/pool/simple_segregated_storage_hpp.html"><img src="../../../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../index.html"><img src="../../../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="../BOOST_POOL_VALIDATE_INTERNALS.html"><img src="../../../../../doc/src/images/next.png" alt="Next"></a>
24</div>
25<div class="refentry">
26<a name="boost.simple_segregated_storage"></a><div class="titlepage"></div>
27<div class="refnamediv">
28<h2><span class="refentrytitle">Class template simple_segregated_storage</span></h2>
29<p>boost::simple_segregated_storage — Simple Segregated Storage is the simplest, and probably the fastest, memory allocation/deallocation algorithm. It is responsible for partitioning a memory block into fixed-size chunks: where the block comes from is determined by the client of the class. </p>
30</div>
31<h2 xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" class="refsynopsisdiv-title">Synopsis</h2>
32<div xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" class="refsynopsisdiv"><pre class="synopsis"><span class="comment">// In header: &lt;<a class="link" href="../header/boost/pool/simple_segregated_storage_hpp.html" title="Header &lt;boost/pool/simple_segregated_storage.hpp&gt;">boost/pool/simple_segregated_storage.hpp</a>&gt;
33
34</span><span class="keyword">template</span><span class="special">&lt;</span><span class="keyword">typename</span> SizeType<span class="special">&gt;</span>
35<span class="keyword">class</span> <a class="link" href="simple_segregated_storage.html" title="Class template simple_segregated_storage">simple_segregated_storage</a> <span class="special">{</span>
36<span class="keyword">public</span><span class="special">:</span>
37  <span class="comment">// types</span>
38  <span class="keyword">typedef</span> <span class="identifier">SizeType</span> <a name="boost.simple_segregated_storage.size_type"></a><span class="identifier">size_type</span><span class="special">;</span>
39
40  <span class="comment">// <a class="link" href="simple_segregated_storage.html#boost.simple_segregated_storageconstruct-copy-destruct">construct/copy/destruct</a></span>
41  <a class="link" href="simple_segregated_storage.html#idm45810836935872-bb"><span class="identifier">simple_segregated_storage</span></a><span class="special">(</span><span class="keyword">const</span> <a class="link" href="simple_segregated_storage.html" title="Class template simple_segregated_storage">simple_segregated_storage</a> <span class="special">&amp;</span><span class="special">)</span><span class="special">;</span>
42  <a class="link" href="simple_segregated_storage.html#idm45810836889488-bb"><span class="identifier">simple_segregated_storage</span></a><span class="special">(</span><span class="special">)</span><span class="special">;</span>
43  <span class="keyword">void</span> <a class="link" href="simple_segregated_storage.html#idm45810836934608-bb"><span class="keyword">operator</span><span class="special">=</span></a><span class="special">(</span><span class="keyword">const</span> <a class="link" href="simple_segregated_storage.html" title="Class template simple_segregated_storage">simple_segregated_storage</a> <span class="special">&amp;</span><span class="special">)</span><span class="special">;</span>
44
45  <span class="comment">// <a class="link" href="simple_segregated_storage.html#idm45810836933088-bb">private static functions</a></span>
46  <span class="keyword">static</span> <span class="keyword">void</span> <span class="special">*</span> <a class="link" href="simple_segregated_storage.html#idm45810836932592-bb"><span class="identifier">try_malloc_n</span></a><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="special">&amp;</span><span class="special">,</span> <span class="identifier">size_type</span><span class="special">,</span> <span class="identifier">size_type</span><span class="special">)</span><span class="special">;</span>
47
48  <span class="comment">// <a class="link" href="simple_segregated_storage.html#idm45810836927504-bb">protected member functions</a></span>
49  <span class="keyword">void</span> <span class="special">*</span> <a class="link" href="simple_segregated_storage.html#idm45810836927008-bb"><span class="identifier">find_prev</span></a><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="special">)</span><span class="special">;</span>
50
51  <span class="comment">// <a class="link" href="simple_segregated_storage.html#idm45810836923360-bb">protected static functions</a></span>
52  <span class="keyword">static</span> <span class="keyword">void</span> <span class="special">*</span><span class="special">&amp;</span> <a class="link" href="simple_segregated_storage.html#idm45810836922864-bb"><span class="identifier">nextof</span></a><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="keyword">const</span><span class="special">)</span><span class="special">;</span>
53
54  <span class="comment">// <a class="link" href="simple_segregated_storage.html#idm45810836919392-bb">public member functions</a></span>
55  <span class="keyword">void</span> <a class="link" href="simple_segregated_storage.html#idm45810836918896-bb"><span class="identifier">add_block</span></a><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="keyword">const</span><span class="special">,</span> <span class="keyword">const</span> <span class="identifier">size_type</span><span class="special">,</span> <span class="keyword">const</span> <span class="identifier">size_type</span><span class="special">)</span><span class="special">;</span>
56  <span class="keyword">void</span> <a class="link" href="simple_segregated_storage.html#idm45810836914752-bb"><span class="identifier">add_ordered_block</span></a><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="keyword">const</span><span class="special">,</span> <span class="keyword">const</span> <span class="identifier">size_type</span><span class="special">,</span> <span class="keyword">const</span> <span class="identifier">size_type</span><span class="special">)</span><span class="special">;</span>
57  <span class="keyword">bool</span> <a class="link" href="simple_segregated_storage.html#idm45810836911584-bb"><span class="identifier">empty</span></a><span class="special">(</span><span class="special">)</span> <span class="keyword">const</span><span class="special">;</span>
58  <span class="keyword">void</span> <span class="special">*</span> <a class="link" href="simple_segregated_storage.html#idm45810836909072-bb"><span class="identifier">malloc</span></a><span class="special">(</span><span class="special">)</span><span class="special">;</span>
59  <span class="keyword">void</span> <a class="link" href="simple_segregated_storage.html#idm45810836907344-bb"><span class="identifier">free</span></a><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="keyword">const</span><span class="special">)</span><span class="special">;</span>
60  <span class="keyword">void</span> <a class="link" href="simple_segregated_storage.html#idm45810836904464-bb"><span class="identifier">ordered_free</span></a><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="keyword">const</span><span class="special">)</span><span class="special">;</span>
61  <span class="keyword">void</span> <span class="special">*</span> <a class="link" href="simple_segregated_storage.html#idm45810836901472-bb"><span class="identifier">malloc_n</span></a><span class="special">(</span><span class="identifier">size_type</span><span class="special">,</span> <span class="identifier">size_type</span><span class="special">)</span><span class="special">;</span>
62  <span class="keyword">void</span> <a class="link" href="simple_segregated_storage.html#idm45810836898640-bb"><span class="identifier">free_n</span></a><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="keyword">const</span><span class="special">,</span> <span class="keyword">const</span> <span class="identifier">size_type</span><span class="special">,</span> <span class="keyword">const</span> <span class="identifier">size_type</span><span class="special">)</span><span class="special">;</span>
63  <span class="keyword">void</span> <a class="link" href="simple_segregated_storage.html#idm45810836893760-bb"><span class="identifier">ordered_free_n</span></a><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="keyword">const</span><span class="special">,</span> <span class="keyword">const</span> <span class="identifier">size_type</span><span class="special">,</span> <span class="keyword">const</span> <span class="identifier">size_type</span><span class="special">)</span><span class="special">;</span>
64
65  <span class="comment">// <a class="link" href="simple_segregated_storage.html#idm45810836888336-bb">public static functions</a></span>
66  <span class="keyword">static</span> <span class="keyword">void</span> <span class="special">*</span> <a class="link" href="simple_segregated_storage.html#idm45810836887840-bb"><span class="identifier">segregate</span></a><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="special">,</span> <span class="identifier">size_type</span><span class="special">,</span> <span class="identifier">size_type</span><span class="special">,</span> <span class="keyword">void</span> <span class="special">*</span> <span class="special">=</span> <span class="number">0</span><span class="special">)</span><span class="special">;</span>
67<span class="special">}</span><span class="special">;</span></pre></div>
68<div class="refsect1">
69<a name="idm46412772649280"></a><h2>Description</h2>
70<p>Template class <a class="link" href="simple_segregated_storage.html" title="Class template simple_segregated_storage">simple_segregated_storage</a> controls access to a free list of memory chunks. Please note that this is a very simple class, with preconditions on almost all its functions. It is intended to be the fastest and smallest possible quick memory allocator - e.g., something to use in embedded systems. This class delegates many difficult preconditions to the user (i.e., alignment issues).</p>
71<p>An object of type simple_segregated_storage&lt;SizeType&gt; is empty if its free list is empty. If it is not empty, then it is ordered if its free list is ordered. A free list is ordered if repeated calls to <code class="computeroutput">malloc()</code> will result in a constantly-increasing sequence of values, as determined by <code class="computeroutput">std::less&lt;void *&gt;</code>. A member function is <span class="emphasis"><em>order-preserving</em></span> if the free list maintains its order orientation (that is, an ordered free list is still ordered after the member function call). </p>
72<div class="refsect2">
73<a name="idm46412772644544"></a><h3>
74<a name="boost.simple_segregated_storageconstruct-copy-destruct"></a><code class="computeroutput">simple_segregated_storage</code>
75        public
76       construct/copy/destruct</h3>
77<div class="orderedlist"><ol class="orderedlist" type="1">
78<li class="listitem"><pre class="literallayout"><a name="idm45810836935872-bb"></a><span class="identifier">simple_segregated_storage</span><span class="special">(</span><span class="keyword">const</span> <a class="link" href="simple_segregated_storage.html" title="Class template simple_segregated_storage">simple_segregated_storage</a> <span class="special">&amp;</span><span class="special">)</span><span class="special">;</span></pre></li>
79<li class="listitem">
80<pre class="literallayout"><a name="idm45810836889488-bb"></a><span class="identifier">simple_segregated_storage</span><span class="special">(</span><span class="special">)</span><span class="special">;</span></pre>
81<p>Construct empty storage area.
82</p>
83<div class="variablelist"><table border="0" class="variablelist compact">
84<colgroup>
85<col align="left" valign="top">
86<col>
87</colgroup>
88<tbody><tr>
89<td><p><span class="term">Postconditions:</span></p></td>
90<td><p>empty() </p></td>
91</tr></tbody>
92</table></div>
93</li>
94<li class="listitem"><pre class="literallayout"><span class="keyword">void</span> <a name="idm45810836934608-bb"></a><span class="keyword">operator</span><span class="special">=</span><span class="special">(</span><span class="keyword">const</span> <a class="link" href="simple_segregated_storage.html" title="Class template simple_segregated_storage">simple_segregated_storage</a> <span class="special">&amp;</span><span class="special">)</span><span class="special">;</span></pre></li>
95</ol></div>
96</div>
97<div class="refsect2">
98<a name="idm46412772624240"></a><h3>
99<a name="idm45810836933088-bb"></a><code class="computeroutput">simple_segregated_storage</code> private static functions</h3>
100<div class="orderedlist"><ol class="orderedlist" type="1"><li class="listitem">
101<pre class="literallayout"><span class="keyword">static</span> <span class="keyword">void</span> <span class="special">*</span>
102<a name="idm45810836932592-bb"></a><span class="identifier">try_malloc_n</span><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="special">&amp;</span> start<span class="special">,</span> <span class="identifier">size_type</span> n<span class="special">,</span> <span class="identifier">size_type</span> partition_size<span class="special">)</span><span class="special">;</span></pre>
103<p>
104
105</p>
106<div class="variablelist"><table border="0" class="variablelist compact">
107<colgroup>
108<col align="left" valign="top">
109<col>
110</colgroup>
111<tbody>
112<tr>
113<td><p><span class="term">Requires:</span></p></td>
114<td><p>(n &gt; 0), (start != 0), (nextof(start) != 0) </p></td>
115</tr>
116<tr>
117<td><p><span class="term">Postconditions:</span></p></td>
118<td><p>(start != 0) The function attempts to find n contiguous chunks of size partition_size in the free list, starting at start. If it succeds, it returns the last chunk in that contiguous sequence, so that the sequence is known by [start, {retval}] If it fails, it does do either because it's at the end of the free list or hits a non-contiguous chunk. In either case, it will return 0, and set start to the last considered chunk. You are at the end of the free list if nextof(start) == 0. Otherwise, start points to the last chunk in the contiguous sequence, and nextof(start) points to the first chunk in the next contiguous sequence (assuming an ordered free list). </p></td>
119</tr>
120</tbody>
121</table></div>
122</li></ol></div>
123</div>
124<div class="refsect2">
125<a name="idm46412772607744"></a><h3>
126<a name="idm45810836927504-bb"></a><code class="computeroutput">simple_segregated_storage</code> protected member functions</h3>
127<div class="orderedlist"><ol class="orderedlist" type="1"><li class="listitem">
128<pre class="literallayout"><span class="keyword">void</span> <span class="special">*</span> <a name="idm45810836927008-bb"></a><span class="identifier">find_prev</span><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span> ptr<span class="special">)</span><span class="special">;</span></pre>
129<p>Traverses the free list referred to by "first", and returns the iterator previous to where "ptr" would go if it was in the free list. Returns 0 if "ptr" would go at the beginning of the free list (i.e., before "first"). </p>
130<div class="note"><table border="0" summary="Note">
131<tr>
132<td rowspan="2" align="center" valign="top" width="25"><img alt="[Note]" src="../../../../../doc/src/images/note.png"></td>
133<th align="left">Note</th>
134</tr>
135<tr><td align="left" valign="top"><p>Note that this function finds the location previous to where ptr would go if it was in the free list. It does not find the entry in the free list before ptr (unless ptr is already in the free list). Specifically, find_prev(0) will return 0, not the last entry in the free list. </p></td></tr>
136</table></div>
137<p>
138
139</p>
140<div class="variablelist"><table border="0" class="variablelist compact">
141<colgroup>
142<col align="left" valign="top">
143<col>
144</colgroup>
145<tbody><tr>
146<td><p><span class="term">Returns:</span></p></td>
147<td><p>location previous to where ptr would go if it was in the free list. </p></td>
148</tr></tbody>
149</table></div>
150</li></ol></div>
151</div>
152<div class="refsect2">
153<a name="idm46412772596272"></a><h3>
154<a name="idm45810836923360-bb"></a><code class="computeroutput">simple_segregated_storage</code> protected static functions</h3>
155<div class="orderedlist"><ol class="orderedlist" type="1"><li class="listitem">
156<pre class="literallayout"><span class="keyword">static</span> <span class="keyword">void</span> <span class="special">*</span><span class="special">&amp;</span> <a name="idm45810836922864-bb"></a><span class="identifier">nextof</span><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="keyword">const</span> ptr<span class="special">)</span><span class="special">;</span></pre>
157<p>The return value is just *ptr cast to the appropriate type. ptr must not be 0. (For the sake of code readability :)</p>
158<p>As an example, let us assume that we want to truncate the free list after the first chunk. That is, we want to set *first to 0; this will result in a free list with only one entry. The normal way to do this is to first cast first to a pointer to a pointer to void, and then dereference and assign (*static_cast&lt;void **&gt;(first) = 0;). This can be done more easily through the use of this convenience function (nextof(first) = 0;).
159</p>
160<div class="variablelist"><table border="0" class="variablelist compact">
161<colgroup>
162<col align="left" valign="top">
163<col>
164</colgroup>
165<tbody><tr>
166<td><p><span class="term">Returns:</span></p></td>
167<td><p>dereferenced pointer. </p></td>
168</tr></tbody>
169</table></div>
170</li></ol></div>
171</div>
172<div class="refsect2">
173<a name="idm46412772583184"></a><h3>
174<a name="idm45810836919392-bb"></a><code class="computeroutput">simple_segregated_storage</code> public member functions</h3>
175<div class="orderedlist"><ol class="orderedlist" type="1">
176<li class="listitem">
177<pre class="literallayout"><span class="keyword">void</span> <a name="idm45810836918896-bb"></a><span class="identifier">add_block</span><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="keyword">const</span> block<span class="special">,</span> <span class="keyword">const</span> <span class="identifier">size_type</span> nsz<span class="special">,</span>
178               <span class="keyword">const</span> <span class="identifier">size_type</span> npartition_sz<span class="special">)</span><span class="special">;</span></pre>
179<p>Add block Segregate this block and merge its free list into the free list referred to by "first".
180
181</p>
182<div class="variablelist"><table border="0" class="variablelist compact">
183<colgroup>
184<col align="left" valign="top">
185<col>
186</colgroup>
187<tbody>
188<tr>
189<td><p><span class="term">Requires:</span></p></td>
190<td><p>Same as segregate. </p></td>
191</tr>
192<tr>
193<td><p><span class="term">Postconditions:</span></p></td>
194<td><p>!empty() </p></td>
195</tr>
196</tbody>
197</table></div>
198</li>
199<li class="listitem">
200<pre class="literallayout"><span class="keyword">void</span> <a name="idm45810836914752-bb"></a><span class="identifier">add_ordered_block</span><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="keyword">const</span> block<span class="special">,</span> <span class="keyword">const</span> <span class="identifier">size_type</span> nsz<span class="special">,</span>
201                       <span class="keyword">const</span> <span class="identifier">size_type</span> npartition_sz<span class="special">)</span><span class="special">;</span></pre>
202<p>add block (ordered into list) This (slower) version of add_block segregates the block and merges its free list into our free list in the proper order. </p>
203</li>
204<li class="listitem">
205<pre class="literallayout"><span class="keyword">bool</span> <a name="idm45810836911584-bb"></a><span class="identifier">empty</span><span class="special">(</span><span class="special">)</span> <span class="keyword">const</span><span class="special">;</span></pre>
206<p>
207</p>
208<div class="variablelist"><table border="0" class="variablelist compact">
209<colgroup>
210<col align="left" valign="top">
211<col>
212</colgroup>
213<tbody><tr>
214<td><p><span class="term">Returns:</span></p></td>
215<td><p>true only if <a class="link" href="simple_segregated_storage.html" title="Class template simple_segregated_storage">simple_segregated_storage</a> is empty. </p></td>
216</tr></tbody>
217</table></div>
218</li>
219<li class="listitem">
220<pre class="literallayout"><span class="keyword">void</span> <span class="special">*</span> <a name="idm45810836909072-bb"></a><span class="identifier">malloc</span><span class="special">(</span><span class="special">)</span><span class="special">;</span></pre>
221<p>Create a chunk.
222</p>
223<div class="variablelist"><table border="0" class="variablelist compact">
224<colgroup>
225<col align="left" valign="top">
226<col>
227</colgroup>
228<tbody><tr>
229<td><p><span class="term">Requires:</span></p></td>
230<td><p>!empty() Increment the "first" pointer to point to the next chunk. </p></td>
231</tr></tbody>
232</table></div>
233</li>
234<li class="listitem">
235<pre class="literallayout"><span class="keyword">void</span> <a name="idm45810836907344-bb"></a><span class="identifier">free</span><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="keyword">const</span> chunk<span class="special">)</span><span class="special">;</span></pre>
236<p>Free a chunk.
237
238</p>
239<div class="variablelist"><table border="0" class="variablelist compact">
240<colgroup>
241<col align="left" valign="top">
242<col>
243</colgroup>
244<tbody>
245<tr>
246<td><p><span class="term">Requires:</span></p></td>
247<td><p>chunk was previously returned from a malloc() referring to the same free list. </p></td>
248</tr>
249<tr>
250<td><p><span class="term">Postconditions:</span></p></td>
251<td><p>!empty() </p></td>
252</tr>
253</tbody>
254</table></div>
255</li>
256<li class="listitem">
257<pre class="literallayout"><span class="keyword">void</span> <a name="idm45810836904464-bb"></a><span class="identifier">ordered_free</span><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="keyword">const</span> chunk<span class="special">)</span><span class="special">;</span></pre>
258<p>This (slower) implementation of 'free' places the memory back in the list in its proper order.
259
260</p>
261<div class="variablelist"><table border="0" class="variablelist compact">
262<colgroup>
263<col align="left" valign="top">
264<col>
265</colgroup>
266<tbody>
267<tr>
268<td><p><span class="term">Requires:</span></p></td>
269<td><p>chunk was previously returned from a malloc() referring to the same free list </p></td>
270</tr>
271<tr>
272<td><p><span class="term">Postconditions:</span></p></td>
273<td><p>!empty(). </p></td>
274</tr>
275</tbody>
276</table></div>
277</li>
278<li class="listitem">
279<pre class="literallayout"><span class="keyword">void</span> <span class="special">*</span> <a name="idm45810836901472-bb"></a><span class="identifier">malloc_n</span><span class="special">(</span><span class="identifier">size_type</span> n<span class="special">,</span> <span class="identifier">size_type</span> partition_size<span class="special">)</span><span class="special">;</span></pre>
280<p>Attempts to find a contiguous sequence of n partition_sz-sized chunks. If found, removes them all from the free list and returns a pointer to the first. If not found, returns 0. It is strongly recommended (but not required) that the free list be ordered, as this algorithm will fail to find a contiguous sequence unless it is contiguous in the free list as well. Order-preserving. O(N) with respect to the size of the free list. </p>
281</li>
282<li class="listitem">
283<pre class="literallayout"><span class="keyword">void</span> <a name="idm45810836898640-bb"></a><span class="identifier">free_n</span><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="keyword">const</span> chunks<span class="special">,</span> <span class="keyword">const</span> <span class="identifier">size_type</span> n<span class="special">,</span>
284            <span class="keyword">const</span> <span class="identifier">size_type</span> partition_size<span class="special">)</span><span class="special">;</span></pre>
285<p>
286
287</p>
288<div class="note"><table border="0" summary="Note">
289<tr>
290<td rowspan="2" align="center" valign="top" width="25"><img alt="[Note]" src="../../../../../doc/src/images/note.png"></td>
291<th align="left">Note</th>
292</tr>
293<tr><td align="left" valign="top"><p>If you're allocating/deallocating n a lot, you should be using an ordered pool. </p></td></tr>
294</table></div>
295<p>
296</p>
297<div class="variablelist"><table border="0" class="variablelist compact">
298<colgroup>
299<col align="left" valign="top">
300<col>
301</colgroup>
302<tbody>
303<tr>
304<td><p><span class="term">Requires:</span></p></td>
305<td><p>chunks was previously allocated from *this with the same values for n and partition_size. </p></td>
306</tr>
307<tr>
308<td><p><span class="term">Postconditions:</span></p></td>
309<td><p>!empty() </p></td>
310</tr>
311</tbody>
312</table></div>
313</li>
314<li class="listitem">
315<pre class="literallayout"><span class="keyword">void</span> <a name="idm45810836893760-bb"></a><span class="identifier">ordered_free_n</span><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span><span class="keyword">const</span> chunks<span class="special">,</span> <span class="keyword">const</span> <span class="identifier">size_type</span> n<span class="special">,</span>
316                    <span class="keyword">const</span> <span class="identifier">size_type</span> partition_size<span class="special">)</span><span class="special">;</span></pre>
317<p>Free n chunks from order list.
318
319</p>
320<div class="variablelist"><table border="0" class="variablelist compact">
321<colgroup>
322<col align="left" valign="top">
323<col>
324</colgroup>
325<tbody>
326<tr>
327<td><p><span class="term">Requires:</span></p></td>
328<td><p>chunks was previously allocated from *this with the same values for n and partition_size.</p></td>
329</tr>
330<tr>
331<td><p><span class="term">Requires:</span></p></td>
332<td><p>n should not be zero (n == 0 has no effect). </p></td>
333</tr>
334</tbody>
335</table></div>
336</li>
337</ol></div>
338</div>
339<div class="refsect2">
340<a name="idm46412772491264"></a><h3>
341<a name="idm45810836888336-bb"></a><code class="computeroutput">simple_segregated_storage</code> public static functions</h3>
342<div class="orderedlist"><ol class="orderedlist" type="1"><li class="listitem">
343<pre class="literallayout"><span class="keyword">static</span> <span class="keyword">void</span> <span class="special">*</span>
344<a name="idm45810836887840-bb"></a><span class="identifier">segregate</span><span class="special">(</span><span class="keyword">void</span> <span class="special">*</span> block<span class="special">,</span> <span class="identifier">size_type</span> nsz<span class="special">,</span> <span class="identifier">size_type</span> npartition_sz<span class="special">,</span>
345          <span class="keyword">void</span> <span class="special">*</span> end <span class="special">=</span> <span class="number">0</span><span class="special">)</span><span class="special">;</span></pre>
346<p>Segregate block into chunks.
347
348
349
350</p>
351<div class="variablelist"><table border="0" class="variablelist compact">
352<colgroup>
353<col align="left" valign="top">
354<col>
355</colgroup>
356<tbody>
357<tr>
358<td><p><span class="term">Requires:</span></p></td>
359<td><p>npartition_sz &gt;= sizeof(void *) </p></td>
360</tr>
361<tr>
362<td><p><span class="term">Requires:</span></p></td>
363<td><p>npartition_sz = sizeof(void *) * i, for some integer i </p></td>
364</tr>
365<tr>
366<td><p><span class="term">Requires:</span></p></td>
367<td><p>nsz &gt;= npartition_sz </p></td>
368</tr>
369<tr>
370<td><p><span class="term">Requires:</span></p></td>
371<td><p>Block is properly aligned for an array of object of size npartition_sz and array of void *. The requirements above guarantee that any pointer to a chunk (which is a pointer to an element in an array of npartition_sz) may be cast to void **. </p></td>
372</tr>
373</tbody>
374</table></div>
375</li></ol></div>
376</div>
377</div>
378</div>
379<table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr>
380<td align="left"></td>
381<td align="right"><div class="copyright-footer">Copyright © 2000-2006 Stephen Cleary<br>Copyright © 2011 Paul A. Bristow<p>
382        Distributed under the Boost Software License, Version 1.0. (See accompanying
383        file LICENSE_1_0.txt or copy at <a href="http://www.boost.org/LICENSE_1_0.txt" target="_top">http://www.boost.org/LICENSE_1_0.txt</a>)
384      </p>
385</div></td>
386</tr></table>
387<hr>
388<div class="spirit-nav">
389<a accesskey="p" href="../header/boost/pool/simple_segregated_storage_hpp.html"><img src="../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../header/boost/pool/simple_segregated_storage_hpp.html"><img src="../../../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../index.html"><img src="../../../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="../BOOST_POOL_VALIDATE_INTERNALS.html"><img src="../../../../../doc/src/images/next.png" alt="Next"></a>
390</div>
391</body>
392</html>
393