• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
2<html>
3<head>
4<meta http-equiv="Content-Type" content="text/html; charset=US-ASCII">
5<title>Class template circular_buffer_space_optimized</title>
6<link rel="stylesheet" href="../../../doc/src/boostbook.css" type="text/css">
7<meta name="generator" content="DocBook XSL Stylesheets V1.79.1">
8<link rel="home" href="../index.html" title="The Boost C++ Libraries BoostBook Documentation Subset">
9<link rel="up" href="../boost_circular_buffer_c___reference.html#header.boost.circular_buffer.space_optimized_hpp" title="Header &lt;boost/circular_buffer/space_optimized.hpp&gt;">
10<link rel="prev" href="swap_idm46495624055088.html" title="Function template swap">
11<link rel="next" href="../circular_buffer/s14.html" title="Index">
12</head>
13<body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF">
14<table cellpadding="2" width="100%"><tr>
15<td valign="top"><img alt="Boost C++ Libraries" width="277" height="86" src="../../../boost.png"></td>
16<td align="center"><a href="../../../index.html">Home</a></td>
17<td align="center"><a href="../../../libs/libraries.htm">Libraries</a></td>
18<td align="center"><a href="http://www.boost.org/users/people.html">People</a></td>
19<td align="center"><a href="http://www.boost.org/users/faq.html">FAQ</a></td>
20<td align="center"><a href="../../../more/index.htm">More</a></td>
21</tr></table>
22<hr>
23<div class="spirit-nav">
24<a accesskey="p" href="swap_idm46495624055088.html"><img src="../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../boost_circular_buffer_c___reference.html#header.boost.circular_buffer.space_optimized_hpp"><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="../circular_buffer/s14.html"><img src="../../../doc/src/images/next.png" alt="Next"></a>
25</div>
26<div class="refentry">
27<a name="boost.circular_idm46495624036048"></a><div class="titlepage"></div>
28<div class="refnamediv">
29<h2><span class="refentrytitle">Class template circular_buffer_space_optimized</span></h2>
30<p>boost::circular_buffer_space_optimized &#8212; Space optimized circular buffer container adaptor. <code class="computeroutput">T</code> must be a copyable class or must have an noexcept move constructor and move assignment operator. </p>
31</div>
32<h2 xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" class="refsynopsisdiv-title">Synopsis</h2>
33<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="../boost_circular_buffer_c___reference.html#header.boost.circular_buffer.space_optimized_hpp" title="Header &lt;boost/circular_buffer/space_optimized.hpp&gt;">boost/circular_buffer/space_optimized.hpp</a>&gt;
34
35</span><span class="keyword">template</span><span class="special">&lt;</span><span class="keyword">typename</span> T<span class="special">,</span> <span class="keyword">typename</span> Alloc<span class="special">&gt;</span>
36<span class="keyword">class</span> <a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a> <span class="special">:</span>
37  <span class="keyword">private</span> <span class="identifier">boost</span><span class="special">::</span><span class="identifier">circular_buffer</span><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span>
38<span class="special">{</span>
39<span class="keyword">public</span><span class="special">:</span>
40  <span class="comment">// <a class="link" href="circular_idm46495624036048.html#boost.circular_idm46495624036048types">types</a></span>
41  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">value_type</span>             <a name="boost.circular_idm46495624036048.value_type"></a><span class="identifier">value_type</span><span class="special">;</span>
42  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">pointer</span>                <a name="boost.circular_idm46495624036048.pointer"></a><span class="identifier">pointer</span><span class="special">;</span>
43  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">const_pointer</span>          <a name="boost.circular_idm46495624036048.const_pointer"></a><span class="identifier">const_pointer</span><span class="special">;</span>
44  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">reference</span>              <a name="boost.circular_idm46495624036048.reference"></a><span class="identifier">reference</span><span class="special">;</span>
45  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">const_reference</span>        <a name="boost.circular_idm46495624036048.const_reference"></a><span class="identifier">const_reference</span><span class="special">;</span>
46  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">size_type</span>              <a name="boost.circular_idm46495624036048.size_type"></a><span class="identifier">size_type</span><span class="special">;</span>
47  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">difference_type</span>        <a name="boost.circular_idm46495624036048.difference_type"></a><span class="identifier">difference_type</span><span class="special">;</span>
48  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">allocator_type</span>         <a name="boost.circular_idm46495624036048.allocator_type"></a><span class="identifier">allocator_type</span><span class="special">;</span>
49  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">const_iterator</span>         <a name="boost.circular_idm46495624036048.const_iterator"></a><span class="identifier">const_iterator</span><span class="special">;</span>
50  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">iterator</span>               <a name="boost.circular_idm46495624036048.iterator"></a><span class="identifier">iterator</span><span class="special">;</span>
51  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">const_reverse_iterator</span> <a name="boost.circular_idm46495624036048.const_reverse_iterator"></a><span class="identifier">const_reverse_iterator</span><span class="special">;</span>
52  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">reverse_iterator</span>       <a name="boost.circular_idm46495624036048.reverse_iterator"></a><span class="identifier">reverse_iterator</span><span class="special">;</span>
53  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">array_range</span>            <a name="boost.circular_idm46495624036048.array_range"></a><span class="identifier">array_range</span><span class="special">;</span>
54  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">const_array_range</span>      <a name="boost.circular_idm46495624036048.const_array_range"></a><span class="identifier">const_array_range</span><span class="special">;</span>
55  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">param_value_type</span>       <a name="boost.circular_idm46495624036048.param_value_type"></a><span class="identifier">param_value_type</span><span class="special">;</span>
56  <span class="keyword">typedef</span> <a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span><span class="special">::</span><span class="identifier">rvalue_type</span>            <a name="boost.circular_idm46495624036048.rvalue_type"></a><span class="identifier">rvalue_type</span><span class="special">;</span>
57  <span class="keyword">typedef</span> <span class="identifier">cb_details</span><span class="special">::</span><span class="identifier">capacity_control</span><span class="special">&lt;</span> <span class="identifier">size_type</span> <span class="special">&gt;</span>           <a class="link" href="circular_idm46495624036048.html#boost.circular_idm46495624036048.capacity_type"><span class="identifier">capacity_type</span></a><span class="special">;</span>
58
59  <span class="comment">// <a class="link" href="circular_idm46495624036048.html#boost.circular_idm46495624036048construct-copy-destruct">construct/copy/destruct</a></span>
60  <span class="keyword">explicit</span> <a class="link" href="circular_idm46495624036048.html#idm46495623268224-bb"><span class="identifier">circular_buffer_space_optimized</span></a><span class="special">(</span><span class="keyword">const</span> <span class="identifier">allocator_type</span> <span class="special">&amp;</span> <span class="special">=</span> <span class="identifier">allocator_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span> <span class="keyword">noexcept</span><span class="special">;</span>
61  <span class="keyword">explicit</span> <a class="link" href="circular_idm46495624036048.html#idm46495623261728-bb"><span class="identifier">circular_buffer_space_optimized</span></a><span class="special">(</span><span class="identifier">capacity_type</span><span class="special">,</span>
62                                           <span class="keyword">const</span> <span class="identifier">allocator_type</span> <span class="special">&amp;</span> <span class="special">=</span> <span class="identifier">allocator_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span><span class="special">;</span>
63  <a class="link" href="circular_idm46495624036048.html#idm46495623252864-bb"><span class="identifier">circular_buffer_space_optimized</span></a><span class="special">(</span><span class="identifier">capacity_type</span><span class="special">,</span> <span class="identifier">param_value_type</span><span class="special">,</span>
64                                  <span class="keyword">const</span> <span class="identifier">allocator_type</span> <span class="special">&amp;</span> <span class="special">=</span> <span class="identifier">allocator_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span><span class="special">;</span>
65  <a class="link" href="circular_idm46495624036048.html#idm46495623240352-bb"><span class="identifier">circular_buffer_space_optimized</span></a><span class="special">(</span><span class="identifier">capacity_type</span><span class="special">,</span> <span class="identifier">size_type</span><span class="special">,</span> <span class="identifier">param_value_type</span><span class="special">,</span>
66                                  <span class="keyword">const</span> <span class="identifier">allocator_type</span> <span class="special">&amp;</span> <span class="special">=</span> <span class="identifier">allocator_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span><span class="special">;</span>
67  <a class="link" href="circular_idm46495624036048.html#idm46495623225008-bb"><span class="identifier">circular_buffer_space_optimized</span></a><span class="special">(</span><span class="keyword">const</span> <a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span> <span class="special">&amp;</span><span class="special">)</span><span class="special">;</span>
68  <a class="link" href="circular_idm46495624036048.html#idm46495623215776-bb"><span class="identifier">circular_buffer_space_optimized</span></a><span class="special">(</span><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span> <span class="special">&amp;&amp;</span><span class="special">)</span> <span class="keyword">noexcept</span><span class="special">;</span>
69  <span class="keyword">template</span><span class="special">&lt;</span><span class="keyword">typename</span> InputIterator<span class="special">&gt;</span>
70    <a class="link" href="circular_idm46495624036048.html#idm46495623207584-bb"><span class="identifier">circular_buffer_space_optimized</span></a><span class="special">(</span><span class="identifier">InputIterator</span><span class="special">,</span> <span class="identifier">InputIterator</span><span class="special">,</span>
71                                    <span class="keyword">const</span> <span class="identifier">allocator_type</span> <span class="special">&amp;</span> <span class="special">=</span> <span class="identifier">allocator_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span><span class="special">;</span>
72  <span class="keyword">template</span><span class="special">&lt;</span><span class="keyword">typename</span> InputIterator<span class="special">&gt;</span>
73    <a class="link" href="circular_idm46495624036048.html#idm46495623193040-bb"><span class="identifier">circular_buffer_space_optimized</span></a><span class="special">(</span><span class="identifier">capacity_type</span><span class="special">,</span> <span class="identifier">InputIterator</span><span class="special">,</span>
74                                    <span class="identifier">InputIterator</span><span class="special">,</span>
75                                    <span class="keyword">const</span> <span class="identifier">allocator_type</span> <span class="special">&amp;</span> <span class="special">=</span> <span class="identifier">allocator_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span><span class="special">;</span>
76  <a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span> <span class="special">&amp;</span>
77  <a class="link" href="circular_idm46495624036048.html#idm46495623173392-bb"><span class="keyword">operator</span><span class="special">=</span></a><span class="special">(</span><span class="keyword">const</span> <a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span> <span class="special">&amp;</span><span class="special">)</span><span class="special">;</span>
78  <a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span> <span class="special">&amp;</span>
79  <a class="link" href="circular_idm46495624036048.html#idm46495623156256-bb"><span class="keyword">operator</span><span class="special">=</span></a><span class="special">(</span><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span> <span class="special">&amp;&amp;</span><span class="special">)</span> <span class="keyword">noexcept</span><span class="special">;</span>
80
81  <span class="comment">// <a class="link" href="circular_idm46495624036048.html#idm46495623999456-bb">public member functions</a></span>
82  <span class="keyword">bool</span> <a class="link" href="circular_idm46495624036048.html#idm46495623998896-bb"><span class="identifier">full</span></a><span class="special">(</span><span class="special">)</span> <span class="keyword">const</span> <span class="keyword">noexcept</span><span class="special">;</span>
83  <span class="identifier">size_type</span> <a class="link" href="circular_idm46495624036048.html#idm46495623986800-bb"><span class="identifier">reserve</span></a><span class="special">(</span><span class="special">)</span> <span class="keyword">const</span> <span class="keyword">noexcept</span><span class="special">;</span>
84  <span class="keyword">const</span> <span class="identifier">capacity_type</span> <span class="special">&amp;</span> <a class="link" href="circular_idm46495624036048.html#idm46495623975968-bb"><span class="identifier">capacity</span></a><span class="special">(</span><span class="special">)</span> <span class="keyword">const</span> <span class="keyword">noexcept</span><span class="special">;</span>
85  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623964032-bb"><span class="identifier">set_capacity</span></a><span class="special">(</span><span class="keyword">const</span> <span class="identifier">capacity_type</span> <span class="special">&amp;</span><span class="special">)</span><span class="special">;</span>
86  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623940880-bb"><span class="identifier">resize</span></a><span class="special">(</span><span class="identifier">size_type</span><span class="special">,</span> <span class="identifier">param_value_type</span> <span class="special">=</span> <span class="identifier">value_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span><span class="special">;</span>
87  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623918144-bb"><span class="identifier">rset_capacity</span></a><span class="special">(</span><span class="keyword">const</span> <span class="identifier">capacity_type</span> <span class="special">&amp;</span><span class="special">)</span><span class="special">;</span>
88  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623899392-bb"><span class="identifier">rresize</span></a><span class="special">(</span><span class="identifier">size_type</span><span class="special">,</span> <span class="identifier">param_value_type</span> <span class="special">=</span> <span class="identifier">value_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span><span class="special">;</span>
89  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623876656-bb"><span class="identifier">assign</span></a><span class="special">(</span><span class="identifier">size_type</span><span class="special">,</span> <span class="identifier">param_value_type</span><span class="special">)</span><span class="special">;</span>
90  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623857376-bb"><span class="identifier">assign</span></a><span class="special">(</span><span class="identifier">capacity_type</span><span class="special">,</span> <span class="identifier">size_type</span><span class="special">,</span> <span class="identifier">param_value_type</span><span class="special">)</span><span class="special">;</span>
91  <span class="keyword">template</span><span class="special">&lt;</span><span class="keyword">typename</span> InputIterator<span class="special">&gt;</span> <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623835184-bb"><span class="identifier">assign</span></a><span class="special">(</span><span class="identifier">InputIterator</span><span class="special">,</span> <span class="identifier">InputIterator</span><span class="special">)</span><span class="special">;</span>
92  <span class="keyword">template</span><span class="special">&lt;</span><span class="keyword">typename</span> InputIterator<span class="special">&gt;</span>
93    <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623814080-bb"><span class="identifier">assign</span></a><span class="special">(</span><span class="identifier">capacity_type</span><span class="special">,</span> <span class="identifier">InputIterator</span><span class="special">,</span> <span class="identifier">InputIterator</span><span class="special">)</span><span class="special">;</span>
94  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623787248-bb"><span class="identifier">swap</span></a><span class="special">(</span><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span> <span class="special">&amp;</span><span class="special">)</span> <span class="keyword">noexcept</span><span class="special">;</span>
95  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623772752-bb"><span class="identifier">push_back</span></a><span class="special">(</span><span class="identifier">param_value_type</span><span class="special">)</span><span class="special">;</span>
96  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623756880-bb"><span class="identifier">push_back</span></a><span class="special">(</span><span class="identifier">rvalue_type</span><span class="special">)</span><span class="special">;</span>
97  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623741472-bb"><span class="identifier">push_back</span></a><span class="special">(</span><span class="special">)</span><span class="special">;</span>
98  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623725824-bb"><span class="identifier">push_front</span></a><span class="special">(</span><span class="identifier">param_value_type</span><span class="special">)</span><span class="special">;</span>
99  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623709952-bb"><span class="identifier">push_front</span></a><span class="special">(</span><span class="identifier">rvalue_type</span><span class="special">)</span><span class="special">;</span>
100  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623693632-bb"><span class="identifier">push_front</span></a><span class="special">(</span><span class="special">)</span><span class="special">;</span>
101  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623677984-bb"><span class="identifier">pop_back</span></a><span class="special">(</span><span class="special">)</span><span class="special">;</span>
102  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623664368-bb"><span class="identifier">pop_front</span></a><span class="special">(</span><span class="special">)</span><span class="special">;</span>
103  <span class="identifier">iterator</span> <a class="link" href="circular_idm46495624036048.html#idm46495623650752-bb"><span class="identifier">insert</span></a><span class="special">(</span><span class="identifier">iterator</span><span class="special">,</span> <span class="identifier">param_value_type</span><span class="special">)</span><span class="special">;</span>
104  <span class="identifier">iterator</span> <a class="link" href="circular_idm46495624036048.html#idm46495623625728-bb"><span class="identifier">insert</span></a><span class="special">(</span><span class="identifier">iterator</span><span class="special">,</span> <span class="identifier">rvalue_type</span><span class="special">)</span><span class="special">;</span>
105  <span class="identifier">iterator</span> <a class="link" href="circular_idm46495624036048.html#idm46495623600720-bb"><span class="identifier">insert</span></a><span class="special">(</span><span class="identifier">iterator</span><span class="special">)</span><span class="special">;</span>
106  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623576384-bb"><span class="identifier">insert</span></a><span class="special">(</span><span class="identifier">iterator</span><span class="special">,</span> <span class="identifier">size_type</span><span class="special">,</span> <span class="identifier">param_value_type</span><span class="special">)</span><span class="special">;</span>
107  <span class="keyword">template</span><span class="special">&lt;</span><span class="keyword">typename</span> InputIterator<span class="special">&gt;</span>
108    <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623543824-bb"><span class="identifier">insert</span></a><span class="special">(</span><span class="identifier">iterator</span><span class="special">,</span> <span class="identifier">InputIterator</span><span class="special">,</span> <span class="identifier">InputIterator</span><span class="special">)</span><span class="special">;</span>
109  <span class="identifier">iterator</span> <a class="link" href="circular_idm46495624036048.html#idm46495623505200-bb"><span class="identifier">rinsert</span></a><span class="special">(</span><span class="identifier">iterator</span><span class="special">,</span> <span class="identifier">param_value_type</span><span class="special">)</span><span class="special">;</span>
110  <span class="identifier">iterator</span> <a class="link" href="circular_idm46495624036048.html#idm46495623480192-bb"><span class="identifier">rinsert</span></a><span class="special">(</span><span class="identifier">iterator</span><span class="special">,</span> <span class="identifier">rvalue_type</span><span class="special">)</span><span class="special">;</span>
111  <span class="identifier">iterator</span> <a class="link" href="circular_idm46495624036048.html#idm46495623455200-bb"><span class="identifier">rinsert</span></a><span class="special">(</span><span class="identifier">iterator</span><span class="special">)</span><span class="special">;</span>
112  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623430880-bb"><span class="identifier">rinsert</span></a><span class="special">(</span><span class="identifier">iterator</span><span class="special">,</span> <span class="identifier">size_type</span><span class="special">,</span> <span class="identifier">param_value_type</span><span class="special">)</span><span class="special">;</span>
113  <span class="keyword">template</span><span class="special">&lt;</span><span class="keyword">typename</span> InputIterator<span class="special">&gt;</span>
114    <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623398352-bb"><span class="identifier">rinsert</span></a><span class="special">(</span><span class="identifier">iterator</span><span class="special">,</span> <span class="identifier">InputIterator</span><span class="special">,</span> <span class="identifier">InputIterator</span><span class="special">)</span><span class="special">;</span>
115  <span class="identifier">iterator</span> <a class="link" href="circular_idm46495624036048.html#idm46495623359728-bb"><span class="identifier">erase</span></a><span class="special">(</span><span class="identifier">iterator</span><span class="special">)</span><span class="special">;</span>
116  <span class="identifier">iterator</span> <a class="link" href="circular_idm46495624036048.html#idm46495623341616-bb"><span class="identifier">erase</span></a><span class="special">(</span><span class="identifier">iterator</span><span class="special">,</span> <span class="identifier">iterator</span><span class="special">)</span><span class="special">;</span>
117  <span class="identifier">iterator</span> <a class="link" href="circular_idm46495624036048.html#idm46495623322720-bb"><span class="identifier">rerase</span></a><span class="special">(</span><span class="identifier">iterator</span><span class="special">)</span><span class="special">;</span>
118  <span class="identifier">iterator</span> <a class="link" href="circular_idm46495624036048.html#idm46495623302480-bb"><span class="identifier">rerase</span></a><span class="special">(</span><span class="identifier">iterator</span><span class="special">,</span> <span class="identifier">iterator</span><span class="special">)</span><span class="special">;</span>
119  <span class="keyword">void</span> <a class="link" href="circular_idm46495624036048.html#idm46495623281280-bb"><span class="identifier">clear</span></a><span class="special">(</span><span class="special">)</span><span class="special">;</span>
120<span class="special">}</span><span class="special">;</span></pre></div>
121<div class="refsect1">
122<a name="id-1.3.9.16.4.3.4"></a><h2>Description</h2>
123<div class="refsect2">
124<a name="id-1.3.9.16.4.3.4.2"></a><h3>
125<a name="boost.circular_idm46495624036048types"></a><code class="computeroutput">circular_buffer_space_optimized</code>
126        public
127       types</h3>
128<div class="orderedlist"><ol class="orderedlist" type="1"><li class="listitem">
129<p>
130<span class="keyword">typedef</span> <span class="identifier">cb_details</span><span class="special">::</span><span class="identifier">capacity_control</span><span class="special">&lt;</span> <span class="identifier">size_type</span> <span class="special">&gt;</span> <a name="boost.circular_idm46495624036048.capacity_type"></a><span class="identifier">capacity_type</span><span class="special">;</span></p>
131<p>Capacity controller of the space optimized circular buffer.</p>
132<p><span class="bold"><strong>See Also:</strong></span></p>
133<p>capacity_control in details.hpp. </p>
134<p>
135</p>
136<p>
137<code class="computeroutput"> class capacity_control<br>
138 {<br>
139 size_type m_capacity; // Available capacity.<br>
140 size_type m_min_capacity; // Minimum capacity.<br>
141 public:<br>
142 capacity_control(size_type capacity, size_type min_capacity = 0)<br>
143 : m_capacity(capacity), m_min_capacity(min_capacity)<br>
144 {};<br>
145 size_type capacity() const { return m_capacity; }<br>
146 size_type min_capacity() const { return m_min_capacity; }<br>
147 operator size_type() const { return m_capacity; }<br>
148 };<br>
149 </code> </p>
150<p>Always <code class="computeroutput">capacity &gt;= min_capacity</code>. </p>
151<p>The <code class="computeroutput">capacity()</code> represents the capacity of the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> and the <code class="computeroutput">min_capacity()</code> determines the minimal allocated size of its internal buffer. </p>
152<p>The converting constructor of the <code class="computeroutput">capacity_control</code> allows implicit conversion from <code class="computeroutput">size_type</code>-like types which ensures compatibility of creating an instance of the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> with other STL containers.</p>
153<p>On the other hand the operator <code class="computeroutput">size_type()</code> provides implicit conversion to the <code class="computeroutput">size_type</code> which allows to treat the capacity of the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> the same way as in the <code class="computeroutput"><a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a></code>. </p>
154</li></ol></div>
155</div>
156<div class="refsect2">
157<a name="id-1.3.9.16.4.3.4.3"></a><h3>
158<a name="boost.circular_idm46495624036048construct-copy-destruct"></a><code class="computeroutput">circular_buffer_space_optimized</code>
159        public
160       construct/copy/destruct</h3>
161<div class="orderedlist"><ol class="orderedlist" type="1">
162<li class="listitem">
163<pre class="literallayout"><span class="keyword">explicit</span> <a name="idm46495623268224-bb"></a><span class="identifier">circular_buffer_space_optimized</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">allocator_type</span> <span class="special">&amp;</span> alloc <span class="special">=</span> <span class="identifier">allocator_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span> <span class="keyword">noexcept</span><span class="special">;</span></pre>Create an empty space optimized circular buffer with zero capacity. <p>
164
165
166</p>
167<p><b>Complexity.&#160;</b>Constant. </p>
168<p>
169</p>
170<div class="warning"><table border="0" summary="Warning">
171<tr>
172<td rowspan="2" align="center" valign="top" width="25"><img alt="[Warning]" src="../../../doc/src/images/warning.png"></td>
173<th align="left">Warning</th>
174</tr>
175<tr><td align="left" valign="top"><p>Since Boost version 1.36 the behaviour of this constructor has changed. Now it creates a space optimized circular buffer with zero capacity. </p></td></tr>
176</table></div>
177<p>
178</p>
179<div class="variablelist"><table border="0" class="variablelist compact">
180<colgroup>
181<col align="left" valign="top">
182<col>
183</colgroup>
184<tbody>
185<tr>
186<td><p><span class="term">Parameters:</span></p></td>
187<td><div class="variablelist"><table border="0" class="variablelist compact">
188<colgroup>
189<col align="left" valign="top">
190<col>
191</colgroup>
192<tbody><tr>
193<td><p><span class="term"><code class="computeroutput">alloc</code></span></p></td>
194<td><p>The allocator. </p></td>
195</tr></tbody>
196</table></div></td>
197</tr>
198<tr>
199<td><p><span class="term">Postconditions:</span></p></td>
200<td><p><code class="computeroutput">capacity().capacity() == 0 &amp;&amp; capacity().min_capacity() == 0 &amp;&amp; size() == 0</code> </p></td>
201</tr>
202<tr>
203<td><p><span class="term">Throws:</span></p></td>
204<td>Nothing. </td>
205</tr>
206</tbody>
207</table></div>
208</li>
209<li class="listitem">
210<pre class="literallayout"><span class="keyword">explicit</span> <a name="idm46495623261728-bb"></a><span class="identifier">circular_buffer_space_optimized</span><span class="special">(</span><span class="identifier">capacity_type</span> capacity_ctrl<span class="special">,</span>
211                                         <span class="keyword">const</span> <span class="identifier">allocator_type</span> <span class="special">&amp;</span> alloc <span class="special">=</span> <span class="identifier">allocator_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span><span class="special">;</span></pre>Create an empty space optimized circular buffer with the specified capacity. <p>
212
213
214</p>
215<p><b>Complexity.&#160;</b>Constant. </p>
216<p>
217</p>
218<div class="variablelist"><table border="0" class="variablelist compact">
219<colgroup>
220<col align="left" valign="top">
221<col>
222</colgroup>
223<tbody>
224<tr>
225<td><p><span class="term">Parameters:</span></p></td>
226<td><div class="variablelist"><table border="0" class="variablelist compact">
227<colgroup>
228<col align="left" valign="top">
229<col>
230</colgroup>
231<tbody>
232<tr>
233<td><p><span class="term"><code class="computeroutput">alloc</code></span></p></td>
234<td><p>The allocator. </p></td>
235</tr>
236<tr>
237<td><p><span class="term"><code class="computeroutput">capacity_ctrl</code></span></p></td>
238<td><p>The capacity controller representing the maximum number of elements which can be stored in the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> and the minimal allocated size of the internal buffer. </p></td>
239</tr>
240</tbody>
241</table></div></td>
242</tr>
243<tr>
244<td><p><span class="term">Postconditions:</span></p></td>
245<td><p><code class="computeroutput">capacity() == capacity_ctrl &amp;&amp; size() == 0</code><br>
246<br>
247 The amount of allocated memory in the internal buffer is <code class="computeroutput">capacity_ctrl.min_capacity()</code>. </p></td>
248</tr>
249<tr>
250<td><p><span class="term">Throws:</span></p></td>
251<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). </td>
252</tr>
253</tbody>
254</table></div>
255</li>
256<li class="listitem">
257<pre class="literallayout"><a name="idm46495623252864-bb"></a><span class="identifier">circular_buffer_space_optimized</span><span class="special">(</span><span class="identifier">capacity_type</span> capacity_ctrl<span class="special">,</span>
258                                <span class="identifier">param_value_type</span> item<span class="special">,</span>
259                                <span class="keyword">const</span> <span class="identifier">allocator_type</span> <span class="special">&amp;</span> alloc <span class="special">=</span> <span class="identifier">allocator_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span><span class="special">;</span></pre>Create a full space optimized circular buffer with the specified capacity filled with <code class="computeroutput">capacity_ctrl.capacity()</code> copies of <code class="computeroutput">item</code>. <p>
260
261
262</p>
263<p><b>Complexity.&#160;</b>Linear (in the <code class="computeroutput">capacity_ctrl.capacity()</code>). </p>
264<p>
265</p>
266<div class="variablelist"><table border="0" class="variablelist compact">
267<colgroup>
268<col align="left" valign="top">
269<col>
270</colgroup>
271<tbody>
272<tr>
273<td><p><span class="term">Parameters:</span></p></td>
274<td><div class="variablelist"><table border="0" class="variablelist compact">
275<colgroup>
276<col align="left" valign="top">
277<col>
278</colgroup>
279<tbody>
280<tr>
281<td><p><span class="term"><code class="computeroutput">alloc</code></span></p></td>
282<td><p>The allocator. </p></td>
283</tr>
284<tr>
285<td><p><span class="term"><code class="computeroutput">capacity_ctrl</code></span></p></td>
286<td><p>The capacity controller representing the maximum number of elements which can be stored in the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> and the minimal allocated size of the internal buffer. </p></td>
287</tr>
288<tr>
289<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
290<td><p>The element the created <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> will be filled with. </p></td>
291</tr>
292</tbody>
293</table></div></td>
294</tr>
295<tr>
296<td><p><span class="term">Postconditions:</span></p></td>
297<td><p><code class="computeroutput">capacity() == capacity_ctrl &amp;&amp; full() &amp;&amp; (*this)[0] == item &amp;&amp; (*this)[1] == item &amp;&amp; ... &amp;&amp; (*this) [capacity_ctrl.capacity() - 1] == item </code><br>
298<br>
299 The amount of allocated memory in the internal buffer is <code class="computeroutput">capacity_ctrl.capacity()</code>. </p></td>
300</tr>
301<tr>
302<td><p><span class="term">Throws:</span></p></td>
303<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). <code class="computeroutput">T::T(const T&amp;)</code> throws. </td>
304</tr>
305</tbody>
306</table></div>
307</li>
308<li class="listitem">
309<pre class="literallayout"><a name="idm46495623240352-bb"></a><span class="identifier">circular_buffer_space_optimized</span><span class="special">(</span><span class="identifier">capacity_type</span> capacity_ctrl<span class="special">,</span> <span class="identifier">size_type</span> n<span class="special">,</span>
310                                <span class="identifier">param_value_type</span> item<span class="special">,</span>
311                                <span class="keyword">const</span> <span class="identifier">allocator_type</span> <span class="special">&amp;</span> alloc <span class="special">=</span> <span class="identifier">allocator_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span><span class="special">;</span></pre>Create a space optimized circular buffer with the specified capacity filled with <code class="computeroutput">n</code> copies of <code class="computeroutput">item</code>. <p>
312
313
314
315</p>
316<p><b>Complexity.&#160;</b>Linear (in the <code class="computeroutput">n</code>). </p>
317<p>
318</p>
319<div class="variablelist"><table border="0" class="variablelist compact">
320<colgroup>
321<col align="left" valign="top">
322<col>
323</colgroup>
324<tbody>
325<tr>
326<td><p><span class="term">Parameters:</span></p></td>
327<td><div class="variablelist"><table border="0" class="variablelist compact">
328<colgroup>
329<col align="left" valign="top">
330<col>
331</colgroup>
332<tbody>
333<tr>
334<td><p><span class="term"><code class="computeroutput">alloc</code></span></p></td>
335<td><p>The allocator. </p></td>
336</tr>
337<tr>
338<td><p><span class="term"><code class="computeroutput">capacity_ctrl</code></span></p></td>
339<td><p>The capacity controller representing the maximum number of elements which can be stored in the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> and the minimal allocated size of the internal buffer. </p></td>
340</tr>
341<tr>
342<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
343<td><p>The element the created <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> will be filled with. </p></td>
344</tr>
345<tr>
346<td><p><span class="term"><code class="computeroutput">n</code></span></p></td>
347<td><p>The number of elements the created <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> will be filled with. </p></td>
348</tr>
349</tbody>
350</table></div></td>
351</tr>
352<tr>
353<td><p><span class="term">Requires:</span></p></td>
354<td><p><code class="computeroutput">capacity_ctrl.capacity() &gt;= n</code> </p></td>
355</tr>
356<tr>
357<td><p><span class="term">Postconditions:</span></p></td>
358<td><p><code class="computeroutput">capacity() == capacity_ctrl &amp;&amp; size() == n &amp;&amp; (*this)[0] == item &amp;&amp; (*this)[1] == item &amp;&amp; ... &amp;&amp; (*this)[n - 1] == item</code><br>
359<br>
360 The amount of allocated memory in the internal buffer is <code class="computeroutput">max[n, capacity_ctrl.min_capacity()]</code>. </p></td>
361</tr>
362<tr>
363<td><p><span class="term">Throws:</span></p></td>
364<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws. </td>
365</tr>
366</tbody>
367</table></div>
368</li>
369<li class="listitem">
370<pre class="literallayout"><a name="idm46495623225008-bb"></a><span class="identifier">circular_buffer_space_optimized</span><span class="special">(</span><span class="keyword">const</span> <a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span> <span class="special">&amp;</span> cb<span class="special">)</span><span class="special">;</span></pre>The copy constructor. <p>Creates a copy of the specified <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>.
371
372
373</p>
374<p><b>Complexity.&#160;</b>Linear (in the size of <code class="computeroutput">cb</code>). </p>
375<p>
376</p>
377<div class="variablelist"><table border="0" class="variablelist compact">
378<colgroup>
379<col align="left" valign="top">
380<col>
381</colgroup>
382<tbody>
383<tr>
384<td><p><span class="term">Parameters:</span></p></td>
385<td><div class="variablelist"><table border="0" class="variablelist compact">
386<colgroup>
387<col align="left" valign="top">
388<col>
389</colgroup>
390<tbody><tr>
391<td><p><span class="term"><code class="computeroutput">cb</code></span></p></td>
392<td><p>The <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> to be copied. </p></td>
393</tr></tbody>
394</table></div></td>
395</tr>
396<tr>
397<td><p><span class="term">Postconditions:</span></p></td>
398<td><p><code class="computeroutput">*this == cb</code><br>
399<br>
400 The amount of allocated memory in the internal buffer is <code class="computeroutput">cb.size()</code>. </p></td>
401</tr>
402<tr>
403<td><p><span class="term">Throws:</span></p></td>
404<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws. </td>
405</tr>
406</tbody>
407</table></div>
408</li>
409<li class="listitem">
410<pre class="literallayout"><a name="idm46495623215776-bb"></a><span class="identifier">circular_buffer_space_optimized</span><span class="special">(</span><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span> <span class="special">&amp;&amp;</span> cb<span class="special">)</span> <span class="keyword">noexcept</span><span class="special">;</span></pre>The move constructor. <p>Move constructs a <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> from <code class="computeroutput">cb</code>, leaving <code class="computeroutput">cb</code> empty.
411
412
413
414</p>
415<p><b>Constant.&#160;</b></p>
416<p>
417</p>
418<div class="variablelist"><table border="0" class="variablelist compact">
419<colgroup>
420<col align="left" valign="top">
421<col>
422</colgroup>
423<tbody>
424<tr>
425<td><p><span class="term">Parameters:</span></p></td>
426<td><div class="variablelist"><table border="0" class="variablelist compact">
427<colgroup>
428<col align="left" valign="top">
429<col>
430</colgroup>
431<tbody><tr>
432<td><p><span class="term"><code class="computeroutput">cb</code></span></p></td>
433<td><p><code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a></code></code> to 'steal' value from. </p></td>
434</tr></tbody>
435</table></div></td>
436</tr>
437<tr>
438<td><p><span class="term">Requires:</span></p></td>
439<td><p>C++ compiler with rvalue references support. </p></td>
440</tr>
441<tr>
442<td><p><span class="term">Postconditions:</span></p></td>
443<td><p><code class="computeroutput">cb.empty()</code> </p></td>
444</tr>
445<tr>
446<td><p><span class="term">Throws:</span></p></td>
447<td>Nothing. </td>
448</tr>
449</tbody>
450</table></div>
451</li>
452<li class="listitem">
453<pre class="literallayout"><span class="keyword">template</span><span class="special">&lt;</span><span class="keyword">typename</span> InputIterator<span class="special">&gt;</span>
454  <a name="idm46495623207584-bb"></a><span class="identifier">circular_buffer_space_optimized</span><span class="special">(</span><span class="identifier">InputIterator</span> first<span class="special">,</span> <span class="identifier">InputIterator</span> last<span class="special">,</span>
455                                  <span class="keyword">const</span> <span class="identifier">allocator_type</span> <span class="special">&amp;</span> alloc <span class="special">=</span> <span class="identifier">allocator_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span><span class="special">;</span></pre>Create a full space optimized circular buffer filled with a copy of the range. <p>
456
457
458
459</p>
460<p><b>Complexity.&#160;</b>Linear (in the <code class="computeroutput">std::distance(first, last)</code>). </p>
461<p>
462</p>
463<div class="variablelist"><table border="0" class="variablelist compact">
464<colgroup>
465<col align="left" valign="top">
466<col>
467</colgroup>
468<tbody>
469<tr>
470<td><p><span class="term">Parameters:</span></p></td>
471<td><div class="variablelist"><table border="0" class="variablelist compact">
472<colgroup>
473<col align="left" valign="top">
474<col>
475</colgroup>
476<tbody>
477<tr>
478<td><p><span class="term"><code class="computeroutput">alloc</code></span></p></td>
479<td><p>The allocator. </p></td>
480</tr>
481<tr>
482<td><p><span class="term"><code class="computeroutput">first</code></span></p></td>
483<td><p>The beginning of the range to be copied. </p></td>
484</tr>
485<tr>
486<td><p><span class="term"><code class="computeroutput">last</code></span></p></td>
487<td><p>The end of the range to be copied. </p></td>
488</tr>
489</tbody>
490</table></div></td>
491</tr>
492<tr>
493<td><p><span class="term">Requires:</span></p></td>
494<td><p>Valid range <code class="computeroutput">[first, last)</code>.<br>
495 <code class="computeroutput">first</code> and <code class="computeroutput">last</code> have to meet the requirements of <a href="https://www.boost.org/sgi/stl/InputIterator.html" target="_top">InputIterator</a>. </p></td>
496</tr>
497<tr>
498<td><p><span class="term">Postconditions:</span></p></td>
499<td><p><code class="computeroutput">capacity().capacity() == std::distance(first, last) &amp;&amp; capacity().min_capacity() == 0 &amp;&amp; full() &amp;&amp; (*this)[0]== *first &amp;&amp; (*this)[1] == *(first + 1) &amp;&amp; ... &amp;&amp; (*this)[std::distance(first, last) - 1] == *(last - 1)</code><br>
500<br>
501 The amount of allocated memory in the internal buffer is <code class="computeroutput">std::distance(first, last)</code>. </p></td>
502</tr>
503<tr>
504<td><p><span class="term">Throws:</span></p></td>
505<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws or nothing if <code class="computeroutput">T::T(T&amp;&amp;)</code> is noexcept and <code class="computeroutput">InputIterator</code> is a move iterator. </td>
506</tr>
507</tbody>
508</table></div>
509</li>
510<li class="listitem">
511<pre class="literallayout"><span class="keyword">template</span><span class="special">&lt;</span><span class="keyword">typename</span> InputIterator<span class="special">&gt;</span>
512  <a name="idm46495623193040-bb"></a><span class="identifier">circular_buffer_space_optimized</span><span class="special">(</span><span class="identifier">capacity_type</span> capacity_ctrl<span class="special">,</span>
513                                  <span class="identifier">InputIterator</span> first<span class="special">,</span> <span class="identifier">InputIterator</span> last<span class="special">,</span>
514                                  <span class="keyword">const</span> <span class="identifier">allocator_type</span> <span class="special">&amp;</span> alloc <span class="special">=</span> <span class="identifier">allocator_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span><span class="special">;</span></pre>Create a space optimized circular buffer with the specified capacity (and the minimal guaranteed amount of allocated memory) filled with a copy of the range. <p>
515
516
517
518</p>
519<p><b>Complexity.&#160;</b>Linear (in <code class="computeroutput">std::distance(first, last)</code>; in <code class="computeroutput">min[capacity_ctrl.capacity(), std::distance(first, last)]</code> if the <code class="computeroutput">InputIterator</code> is a <a href="https://www.boost.org/sgi/stl/RandomAccessIterator.html" target="_top">RandomAccessIterator</a>). </p>
520<p>
521</p>
522<div class="variablelist"><table border="0" class="variablelist compact">
523<colgroup>
524<col align="left" valign="top">
525<col>
526</colgroup>
527<tbody>
528<tr>
529<td><p><span class="term">Parameters:</span></p></td>
530<td><div class="variablelist"><table border="0" class="variablelist compact">
531<colgroup>
532<col align="left" valign="top">
533<col>
534</colgroup>
535<tbody>
536<tr>
537<td><p><span class="term"><code class="computeroutput">alloc</code></span></p></td>
538<td><p>The allocator. </p></td>
539</tr>
540<tr>
541<td><p><span class="term"><code class="computeroutput">capacity_ctrl</code></span></p></td>
542<td><p>The capacity controller representing the maximum number of elements which can be stored in the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> and the minimal allocated size of the internal buffer. </p></td>
543</tr>
544<tr>
545<td><p><span class="term"><code class="computeroutput">first</code></span></p></td>
546<td><p>The beginning of the range to be copied. </p></td>
547</tr>
548<tr>
549<td><p><span class="term"><code class="computeroutput">last</code></span></p></td>
550<td><p>The end of the range to be copied. </p></td>
551</tr>
552</tbody>
553</table></div></td>
554</tr>
555<tr>
556<td><p><span class="term">Requires:</span></p></td>
557<td><p>Valid range <code class="computeroutput">[first, last)</code>.<br>
558 <code class="computeroutput">first</code> and <code class="computeroutput">last</code> have to meet the requirements of <a href="https://www.boost.org/sgi/stl/InputIterator.html" target="_top">InputIterator</a>. </p></td>
559</tr>
560<tr>
561<td><p><span class="term">Postconditions:</span></p></td>
562<td><p><code class="computeroutput">capacity() == capacity_ctrl &amp;&amp; size() &lt;= std::distance(first, last) &amp;&amp; (*this)[0]== (last - capacity_ctrl.capacity()) &amp;&amp; (*this)[1] == *(last - capacity_ctrl.capacity() + 1) &amp;&amp; ... &amp;&amp; (*this)[capacity_ctrl.capacity() - 1] == *(last - 1)</code><br>
563<br>
564 If the number of items to be copied from the range <code class="computeroutput">[first, last)</code> is greater than the specified <code class="computeroutput">capacity_ctrl.capacity()</code> then only elements from the range <code class="computeroutput">[last - capacity_ctrl.capacity(), last)</code> will be copied.<br>
565<br>
566 The amount of allocated memory in the internal buffer is <code class="computeroutput">max[capacity_ctrl.min_capacity(), min[capacity_ctrl.capacity(), std::distance(first, last)]]</code>. </p></td>
567</tr>
568<tr>
569<td><p><span class="term">Throws:</span></p></td>
570<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws. </td>
571</tr>
572</tbody>
573</table></div>
574</li>
575<li class="listitem">
576<pre class="literallayout"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span> <span class="special">&amp;</span>
577<a name="idm46495623173392-bb"></a><span class="keyword">operator</span><span class="special">=</span><span class="special">(</span><span class="keyword">const</span> <a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span> <span class="special">&amp;</span> cb<span class="special">)</span><span class="special">;</span></pre>The assign operator. <p>Makes this <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> to become a copy of the specified <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>.
578
579
580</p>
581<p><b>Exception Safety.&#160;</b>Strong. </p>
582<p>
583</p>
584<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to this <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
585<p>
586</p>
587<p><b>Complexity.&#160;</b>Linear (in the size of <code class="computeroutput">cb</code>). </p>
588<p>
589</p>
590<p><span class="bold"><strong>See Also:</strong></span></p>
591<p><code class="computeroutput">assign(size_type, const_reference)</code>, <code class="computeroutput">assign(capacity_type, size_type, const_reference)</code>, <code class="computeroutput">assign(InputIterator, InputIterator)</code>, <code class="computeroutput">assign(capacity_type, InputIterator, InputIterator)</code> </p>
592<p>
593</p>
594<p>
595</p>
596<div class="variablelist"><table border="0" class="variablelist compact">
597<colgroup>
598<col align="left" valign="top">
599<col>
600</colgroup>
601<tbody>
602<tr>
603<td><p><span class="term">Parameters:</span></p></td>
604<td><div class="variablelist"><table border="0" class="variablelist compact">
605<colgroup>
606<col align="left" valign="top">
607<col>
608</colgroup>
609<tbody><tr>
610<td><p><span class="term"><code class="computeroutput">cb</code></span></p></td>
611<td><p>The <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> to be copied. </p></td>
612</tr></tbody>
613</table></div></td>
614</tr>
615<tr>
616<td><p><span class="term">Postconditions:</span></p></td>
617<td><p><code class="computeroutput">*this == cb</code><br>
618<br>
619 The amount of allocated memory in the internal buffer is <code class="computeroutput">cb.size()</code>. </p></td>
620</tr>
621<tr>
622<td><p><span class="term">Throws:</span></p></td>
623<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). <code class="computeroutput">T::T(const T&amp;)</code> throws. </td>
624</tr>
625</tbody>
626</table></div>
627</li>
628<li class="listitem">
629<pre class="literallayout"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span> <span class="special">&amp;</span>
630<a name="idm46495623156256-bb"></a><span class="keyword">operator</span><span class="special">=</span><span class="special">(</span><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span> <span class="special">&amp;&amp;</span> cb<span class="special">)</span> <span class="keyword">noexcept</span><span class="special">;</span></pre>Move assigns content of <code class="computeroutput">cb</code> to <code class="computeroutput">*this</code>, leaving <code class="computeroutput">cb</code> empty. <p>
631
632
633
634</p>
635<p><b>Complexity.&#160;</b>Constant. </p>
636<p>
637</p>
638<div class="variablelist"><table border="0" class="variablelist compact">
639<colgroup>
640<col align="left" valign="top">
641<col>
642</colgroup>
643<tbody>
644<tr>
645<td><p><span class="term">Parameters:</span></p></td>
646<td><div class="variablelist"><table border="0" class="variablelist compact">
647<colgroup>
648<col align="left" valign="top">
649<col>
650</colgroup>
651<tbody><tr>
652<td><p><span class="term"><code class="computeroutput">cb</code></span></p></td>
653<td><p><code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a></code></code> to 'steal' value from. </p></td>
654</tr></tbody>
655</table></div></td>
656</tr>
657<tr>
658<td><p><span class="term">Requires:</span></p></td>
659<td><p>C++ compiler with rvalue references support. </p></td>
660</tr>
661<tr>
662<td><p><span class="term">Postconditions:</span></p></td>
663<td><p><code class="computeroutput">cb.empty()</code> </p></td>
664</tr>
665<tr>
666<td><p><span class="term">Throws:</span></p></td>
667<td>Nothing. </td>
668</tr>
669</tbody>
670</table></div>
671</li>
672</ol></div>
673</div>
674<div class="refsect2">
675<a name="id-1.3.9.16.4.3.4.4"></a><h3>
676<a name="idm46495623999456-bb"></a><code class="computeroutput">circular_buffer_space_optimized</code> public member functions</h3>
677<div class="orderedlist"><ol class="orderedlist" type="1">
678<li class="listitem">
679<pre class="literallayout"><span class="keyword">bool</span> <a name="idm46495623998896-bb"></a><span class="identifier">full</span><span class="special">(</span><span class="special">)</span> <span class="keyword">const</span> <span class="keyword">noexcept</span><span class="special">;</span></pre>Is the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> full? <p>
680
681</p>
682<p><b>Exception Safety.&#160;</b>No-throw. </p>
683<p>
684</p>
685<p><b>Iterator Invalidation.&#160;</b>Does not invalidate any iterators. </p>
686<p>
687</p>
688<p><b>Complexity.&#160;</b>Constant (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
689<p>
690</p>
691<p><span class="bold"><strong>See Also:</strong></span></p>
692<p><code class="computeroutput">empty()</code> </p>
693<p>
694</p>
695<p>
696</p>
697<div class="variablelist"><table border="0" class="variablelist compact">
698<colgroup>
699<col align="left" valign="top">
700<col>
701</colgroup>
702<tbody>
703<tr>
704<td><p><span class="term">Returns:</span></p></td>
705<td><p><code class="computeroutput">true</code> if the number of elements stored in the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> equals the capacity of the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code>; <code class="computeroutput">false</code> otherwise. </p></td>
706</tr>
707<tr>
708<td><p><span class="term">Throws:</span></p></td>
709<td>Nothing. </td>
710</tr>
711</tbody>
712</table></div>
713</li>
714<li class="listitem">
715<pre class="literallayout"><span class="identifier">size_type</span> <a name="idm46495623986800-bb"></a><span class="identifier">reserve</span><span class="special">(</span><span class="special">)</span> <span class="keyword">const</span> <span class="keyword">noexcept</span><span class="special">;</span></pre>Get the maximum number of elements which can be inserted into the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> without overwriting any of already stored elements. <p>
716
717</p>
718<p><b>Exception Safety.&#160;</b>No-throw. </p>
719<p>
720</p>
721<p><b>Iterator Invalidation.&#160;</b>Does not invalidate any iterators. </p>
722<p>
723</p>
724<p><b>Complexity.&#160;</b>Constant (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
725<p>
726</p>
727<p><span class="bold"><strong>See Also:</strong></span></p>
728<p><code class="computeroutput">capacity()</code>, <code class="computeroutput">size()</code>, <code class="computeroutput">max_size()</code> </p>
729<p>
730</p>
731<p>
732</p>
733<div class="variablelist"><table border="0" class="variablelist compact">
734<colgroup>
735<col align="left" valign="top">
736<col>
737</colgroup>
738<tbody>
739<tr>
740<td><p><span class="term">Returns:</span></p></td>
741<td><p><code class="computeroutput">capacity().capacity() - size()</code> </p></td>
742</tr>
743<tr>
744<td><p><span class="term">Throws:</span></p></td>
745<td>Nothing. </td>
746</tr>
747</tbody>
748</table></div>
749</li>
750<li class="listitem">
751<pre class="literallayout"><span class="keyword">const</span> <span class="identifier">capacity_type</span> <span class="special">&amp;</span> <a name="idm46495623975968-bb"></a><span class="identifier">capacity</span><span class="special">(</span><span class="special">)</span> <span class="keyword">const</span> <span class="keyword">noexcept</span><span class="special">;</span></pre>Get the capacity of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>. <p>
752
753</p>
754<p><b>Exception Safety.&#160;</b>No-throw. </p>
755<p>
756</p>
757<p><b>Iterator Invalidation.&#160;</b>Does not invalidate any iterators. </p>
758<p>
759</p>
760<p><b>Complexity.&#160;</b>Constant (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
761<p>
762</p>
763<p><span class="bold"><strong>See Also:</strong></span></p>
764<p><code class="computeroutput">reserve()</code>, <code class="computeroutput">size()</code>, <code class="computeroutput">max_size()</code>, <code class="computeroutput">set_capacity(const capacity_type&amp;)</code> </p>
765<p>
766</p>
767<p>
768</p>
769<div class="variablelist"><table border="0" class="variablelist compact">
770<colgroup>
771<col align="left" valign="top">
772<col>
773</colgroup>
774<tbody>
775<tr>
776<td><p><span class="term">Returns:</span></p></td>
777<td><p>The capacity controller representing the maximum number of elements which can be stored in the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> and the minimal allocated size of the internal buffer. </p></td>
778</tr>
779<tr>
780<td><p><span class="term">Throws:</span></p></td>
781<td>Nothing. </td>
782</tr>
783</tbody>
784</table></div>
785</li>
786<li class="listitem">
787<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623964032-bb"></a><span class="identifier">set_capacity</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">capacity_type</span> <span class="special">&amp;</span> capacity_ctrl<span class="special">)</span><span class="special">;</span></pre>Change the capacity (and the minimal guaranteed amount of allocated memory) of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>. <p>
788
789
790</p>
791<p><b>Exception Safety.&#160;</b>Strong. </p>
792<p>
793</p>
794<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
795<p>
796</p>
797<p><b>Complexity.&#160;</b>Linear (in <code class="computeroutput">min[size(), capacity_ctrl.capacity()]</code>). </p>
798<p>
799</p>
800<div class="note"><table border="0" summary="Note">
801<tr>
802<td rowspan="2" align="center" valign="top" width="25"><img alt="[Note]" src="../../../doc/src/images/note.png"></td>
803<th align="left">Note</th>
804</tr>
805<tr><td align="left" valign="top"><p>To explicitly clear the extra allocated memory use the <span class="bold"><strong>shrink-to-fit</strong></span> technique:<br>
806<br>
807 <code class="computeroutput">boost::circular_buffer_space_optimized&lt;int&gt; cb(1000);<br>
808 ...<br>
809 boost::circular_buffer_space_optimized&lt;int&gt;(cb).swap(cb);</code><br>
810<br>
811 For more information about the shrink-to-fit technique in STL see <a href="http://www.gotw.ca/gotw/054.htm" target="_top">http://www.gotw.ca/gotw/054.htm</a>. </p></td></tr>
812</table></div>
813<p>
814</p>
815<p><span class="bold"><strong>See Also:</strong></span></p>
816<p><code class="computeroutput">rset_capacity(const capacity_type&amp;)</code>, <code class="computeroutput">resize(size_type, const_reference)</code> </p>
817<p>
818</p>
819<p>
820</p>
821<div class="variablelist"><table border="0" class="variablelist compact">
822<colgroup>
823<col align="left" valign="top">
824<col>
825</colgroup>
826<tbody>
827<tr>
828<td><p><span class="term">Parameters:</span></p></td>
829<td><div class="variablelist"><table border="0" class="variablelist compact">
830<colgroup>
831<col align="left" valign="top">
832<col>
833</colgroup>
834<tbody><tr>
835<td><p><span class="term"><code class="computeroutput">capacity_ctrl</code></span></p></td>
836<td><p>The new capacity controller. </p></td>
837</tr></tbody>
838</table></div></td>
839</tr>
840<tr>
841<td><p><span class="term">Postconditions:</span></p></td>
842<td><p><code class="computeroutput">capacity() == capacity_ctrl &amp;&amp; size() &lt;= capacity_ctrl.capacity()</code><br>
843<br>
844 If the current number of elements stored in the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is greater than the desired new capacity then number of <code class="computeroutput">[size() - capacity_ctrl.capacity()]</code> <span class="bold"><strong>last</strong></span> elements will be removed and the new size will be equal to <code class="computeroutput">capacity_ctrl.capacity()</code>.<br>
845<br>
846 If the current number of elements stored in the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is lower than the new capacity then the amount of allocated memory in the internal buffer may be accommodated as necessary but it will never drop below <code class="computeroutput">capacity_ctrl.min_capacity()</code>. </p></td>
847</tr>
848<tr>
849<td><p><span class="term">Throws:</span></p></td>
850<td>An allocation error if memory is exhausted, (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws or nothing if <code class="computeroutput">T::T(T&amp;&amp;)</code> is noexcept. </td>
851</tr>
852</tbody>
853</table></div>
854</li>
855<li class="listitem">
856<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623940880-bb"></a><span class="identifier">resize</span><span class="special">(</span><span class="identifier">size_type</span> new_size<span class="special">,</span> <span class="identifier">param_value_type</span> item <span class="special">=</span> <span class="identifier">value_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span><span class="special">;</span></pre>Change the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>. <p>
857
858
859</p>
860<p><b>Exception Safety.&#160;</b>Basic. </p>
861<p>
862</p>
863<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
864<p>
865</p>
866<p><b>Complexity.&#160;</b>Linear (in the new size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
867<p>
868</p>
869<p><span class="bold"><strong>See Also:</strong></span></p>
870<p><code class="computeroutput">rresize(size_type, const_reference)</code>, <code class="computeroutput">set_capacity(const capacity_type&amp;)</code> </p>
871<p>
872</p>
873<p>
874</p>
875<div class="variablelist"><table border="0" class="variablelist compact">
876<colgroup>
877<col align="left" valign="top">
878<col>
879</colgroup>
880<tbody>
881<tr>
882<td><p><span class="term">Parameters:</span></p></td>
883<td><div class="variablelist"><table border="0" class="variablelist compact">
884<colgroup>
885<col align="left" valign="top">
886<col>
887</colgroup>
888<tbody>
889<tr>
890<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
891<td><p>The element the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> will be filled with in order to gain the requested size. (See the <span class="emphasis"><em>Effect</em></span>.) </p></td>
892</tr>
893<tr>
894<td><p><span class="term"><code class="computeroutput">new_size</code></span></p></td>
895<td><p>The new size. </p></td>
896</tr>
897</tbody>
898</table></div></td>
899</tr>
900<tr>
901<td><p><span class="term">Postconditions:</span></p></td>
902<td><p><code class="computeroutput">size() == new_size &amp;&amp; capacity().capacity() &gt;= new_size</code><br>
903<br>
904 If the new size is greater than the current size, copies of <code class="computeroutput">item</code> will be inserted at the <span class="bold"><strong>back</strong></span> of the of the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> in order to achieve the desired size. In the case the resulting size exceeds the current capacity the capacity will be set to <code class="computeroutput">new_size</code>.<br>
905<br>
906 If the current number of elements stored in the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is greater than the desired new size then number of <code class="computeroutput">[size() - new_size]</code> <span class="bold"><strong>last</strong></span> elements will be removed. (The capacity will remain unchanged.)<br>
907<br>
908 The amount of allocated memory in the internal buffer may be accommodated as necessary. </p></td>
909</tr>
910<tr>
911<td><p><span class="term">Throws:</span></p></td>
912<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws. </td>
913</tr>
914</tbody>
915</table></div>
916</li>
917<li class="listitem">
918<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623918144-bb"></a><span class="identifier">rset_capacity</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">capacity_type</span> <span class="special">&amp;</span> capacity_ctrl<span class="special">)</span><span class="special">;</span></pre>Change the capacity (and the minimal guaranteed amount of allocated memory) of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>. <p>
919
920
921</p>
922<p><b>Exception Safety.&#160;</b>Strong. </p>
923<p>
924</p>
925<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
926<p>
927</p>
928<p><b>Complexity.&#160;</b>Linear (in <code class="computeroutput">min[size(), capacity_ctrl.capacity()]</code>). </p>
929<p>
930</p>
931<p><span class="bold"><strong>See Also:</strong></span></p>
932<p><code class="computeroutput">set_capacity(const capacity_type&amp;)</code>, <code class="computeroutput">rresize(size_type, const_reference)</code> </p>
933<p>
934</p>
935<p>
936</p>
937<div class="variablelist"><table border="0" class="variablelist compact">
938<colgroup>
939<col align="left" valign="top">
940<col>
941</colgroup>
942<tbody>
943<tr>
944<td><p><span class="term">Parameters:</span></p></td>
945<td><div class="variablelist"><table border="0" class="variablelist compact">
946<colgroup>
947<col align="left" valign="top">
948<col>
949</colgroup>
950<tbody><tr>
951<td><p><span class="term"><code class="computeroutput">capacity_ctrl</code></span></p></td>
952<td><p>The new capacity controller. </p></td>
953</tr></tbody>
954</table></div></td>
955</tr>
956<tr>
957<td><p><span class="term">Postconditions:</span></p></td>
958<td><p><code class="computeroutput">capacity() == capacity_ctrl &amp;&amp; size() &lt;= capacity_ctrl</code><br>
959<br>
960 If the current number of elements stored in the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is greater than the desired new capacity then number of <code class="computeroutput">[size() - capacity_ctrl.capacity()]</code> <span class="bold"><strong>first</strong></span> elements will be removed and the new size will be equal to <code class="computeroutput">capacity_ctrl.capacity()</code>.<br>
961<br>
962 If the current number of elements stored in the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is lower than the new capacity then the amount of allocated memory in the internal buffer may be accommodated as necessary but it will never drop below <code class="computeroutput">capacity_ctrl.min_capacity()</code>. </p></td>
963</tr>
964<tr>
965<td><p><span class="term">Throws:</span></p></td>
966<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws or nothing if <code class="computeroutput">T::T(T&amp;&amp;)</code> is noexcept. </td>
967</tr>
968</tbody>
969</table></div>
970</li>
971<li class="listitem">
972<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623899392-bb"></a><span class="identifier">rresize</span><span class="special">(</span><span class="identifier">size_type</span> new_size<span class="special">,</span> <span class="identifier">param_value_type</span> item <span class="special">=</span> <span class="identifier">value_type</span><span class="special">(</span><span class="special">)</span><span class="special">)</span><span class="special">;</span></pre>Change the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>. <p>
973
974
975</p>
976<p><b>Exception Safety.&#160;</b>Basic. </p>
977<p>
978</p>
979<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
980<p>
981</p>
982<p><b>Complexity.&#160;</b>Linear (in the new size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
983<p>
984</p>
985<p><span class="bold"><strong>See Also:</strong></span></p>
986<p><code class="computeroutput">resize(size_type, const_reference)</code>, <code class="computeroutput">rset_capacity(const capacity_type&amp;)</code> </p>
987<p>
988</p>
989<p>
990</p>
991<div class="variablelist"><table border="0" class="variablelist compact">
992<colgroup>
993<col align="left" valign="top">
994<col>
995</colgroup>
996<tbody>
997<tr>
998<td><p><span class="term">Parameters:</span></p></td>
999<td><div class="variablelist"><table border="0" class="variablelist compact">
1000<colgroup>
1001<col align="left" valign="top">
1002<col>
1003</colgroup>
1004<tbody>
1005<tr>
1006<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
1007<td><p>The element the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> will be filled with in order to gain the requested size. (See the <span class="emphasis"><em>Effect</em></span>.) </p></td>
1008</tr>
1009<tr>
1010<td><p><span class="term"><code class="computeroutput">new_size</code></span></p></td>
1011<td><p>The new size. </p></td>
1012</tr>
1013</tbody>
1014</table></div></td>
1015</tr>
1016<tr>
1017<td><p><span class="term">Postconditions:</span></p></td>
1018<td><p><code class="computeroutput">size() == new_size &amp;&amp; capacity().capacity() &gt;= new_size</code><br>
1019<br>
1020 If the new size is greater than the current size, copies of <code class="computeroutput">item</code> will be inserted at the <span class="bold"><strong>front</strong></span> of the of the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> in order to achieve the desired size. In the case the resulting size exceeds the current capacity the capacity will be set to <code class="computeroutput">new_size</code>.<br>
1021<br>
1022 If the current number of elements stored in the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is greater than the desired new size then number of <code class="computeroutput">[size() - new_size]</code> <span class="bold"><strong>first</strong></span> elements will be removed. (The capacity will remain unchanged.)<br>
1023<br>
1024 The amount of allocated memory in the internal buffer may be accommodated as necessary. </p></td>
1025</tr>
1026<tr>
1027<td><p><span class="term">Throws:</span></p></td>
1028<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws. </td>
1029</tr>
1030</tbody>
1031</table></div>
1032</li>
1033<li class="listitem">
1034<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623876656-bb"></a><span class="identifier">assign</span><span class="special">(</span><span class="identifier">size_type</span> n<span class="special">,</span> <span class="identifier">param_value_type</span> item<span class="special">)</span><span class="special">;</span></pre>Assign <code class="computeroutput">n</code> items into the space optimized circular buffer. <p>The content of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> will be removed and replaced with <code class="computeroutput">n</code> copies of the <code class="computeroutput">item</code>.
1035
1036
1037</p>
1038<p><b>Exception Safety.&#160;</b>Basic. </p>
1039<p>
1040</p>
1041<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1042<p>
1043</p>
1044<p><b>Complexity.&#160;</b>Linear (in the <code class="computeroutput">n</code>). </p>
1045<p>
1046</p>
1047<p><span class="bold"><strong>See Also:</strong></span></p>
1048<p><code class="computeroutput">operator=</code>, <code class="computeroutput">assign(capacity_type, size_type, const_reference)</code>, <code class="computeroutput">assign(InputIterator, InputIterator)</code>, <code class="computeroutput">assign(capacity_type, InputIterator, InputIterator)</code> </p>
1049<p>
1050</p>
1051<p>
1052</p>
1053<div class="variablelist"><table border="0" class="variablelist compact">
1054<colgroup>
1055<col align="left" valign="top">
1056<col>
1057</colgroup>
1058<tbody>
1059<tr>
1060<td><p><span class="term">Parameters:</span></p></td>
1061<td><div class="variablelist"><table border="0" class="variablelist compact">
1062<colgroup>
1063<col align="left" valign="top">
1064<col>
1065</colgroup>
1066<tbody>
1067<tr>
1068<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
1069<td><p>The element the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> will be filled with. </p></td>
1070</tr>
1071<tr>
1072<td><p><span class="term"><code class="computeroutput">n</code></span></p></td>
1073<td><p>The number of elements the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> will be filled with. </p></td>
1074</tr>
1075</tbody>
1076</table></div></td>
1077</tr>
1078<tr>
1079<td><p><span class="term">Postconditions:</span></p></td>
1080<td><p><code class="computeroutput">capacity().capacity() == n &amp;&amp; capacity().min_capacity() == 0 &amp;&amp; size() == n &amp;&amp; (*this)[0] == item &amp;&amp; (*this)[1] == item &amp;&amp; ... &amp;&amp; (*this) [n - 1] == item</code><br>
1081<br>
1082 The amount of allocated memory in the internal buffer is <code class="computeroutput">n</code>. </p></td>
1083</tr>
1084<tr>
1085<td><p><span class="term">Throws:</span></p></td>
1086<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws. </td>
1087</tr>
1088</tbody>
1089</table></div>
1090</li>
1091<li class="listitem">
1092<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623857376-bb"></a><span class="identifier">assign</span><span class="special">(</span><span class="identifier">capacity_type</span> capacity_ctrl<span class="special">,</span> <span class="identifier">size_type</span> n<span class="special">,</span> <span class="identifier">param_value_type</span> item<span class="special">)</span><span class="special">;</span></pre>Assign <code class="computeroutput">n</code> items into the space optimized circular buffer specifying the capacity. <p>The capacity of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> will be set to the specified value and the content of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> will be removed and replaced with <code class="computeroutput">n</code> copies of the <code class="computeroutput">item</code>.
1093
1094
1095
1096</p>
1097<p><b>Exception Safety.&#160;</b>Basic. </p>
1098<p>
1099</p>
1100<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1101<p>
1102</p>
1103<p><b>Complexity.&#160;</b>Linear (in the <code class="computeroutput">n</code>). </p>
1104<p>
1105</p>
1106<p><span class="bold"><strong>See Also:</strong></span></p>
1107<p><code class="computeroutput">operator=</code>, <code class="computeroutput">assign(size_type, const_reference)</code>, <code class="computeroutput">assign(InputIterator, InputIterator)</code>, <code class="computeroutput">assign(capacity_type, InputIterator, InputIterator)</code> </p>
1108<p>
1109</p>
1110<p>
1111</p>
1112<div class="variablelist"><table border="0" class="variablelist compact">
1113<colgroup>
1114<col align="left" valign="top">
1115<col>
1116</colgroup>
1117<tbody>
1118<tr>
1119<td><p><span class="term">Parameters:</span></p></td>
1120<td><div class="variablelist"><table border="0" class="variablelist compact">
1121<colgroup>
1122<col align="left" valign="top">
1123<col>
1124</colgroup>
1125<tbody>
1126<tr>
1127<td><p><span class="term"><code class="computeroutput">capacity_ctrl</code></span></p></td>
1128<td><p>The new capacity controller. </p></td>
1129</tr>
1130<tr>
1131<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
1132<td><p>The element the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> will be filled with. </p></td>
1133</tr>
1134<tr>
1135<td><p><span class="term"><code class="computeroutput">n</code></span></p></td>
1136<td><p>The number of elements the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> will be filled with. </p></td>
1137</tr>
1138</tbody>
1139</table></div></td>
1140</tr>
1141<tr>
1142<td><p><span class="term">Requires:</span></p></td>
1143<td><p><code class="computeroutput">capacity_ctrl.capacity() &gt;= n</code> </p></td>
1144</tr>
1145<tr>
1146<td><p><span class="term">Postconditions:</span></p></td>
1147<td><p><code class="computeroutput">capacity() == capacity_ctrl &amp;&amp; size() == n &amp;&amp; (*this)[0] == item &amp;&amp; (*this)[1] == item &amp;&amp; ... &amp;&amp; (*this) [n - 1] == item </code><br>
1148<br>
1149 The amount of allocated memory will be <code class="computeroutput">max[n, capacity_ctrl.min_capacity()]</code>. </p></td>
1150</tr>
1151<tr>
1152<td><p><span class="term">Throws:</span></p></td>
1153<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws. </td>
1154</tr>
1155</tbody>
1156</table></div>
1157</li>
1158<li class="listitem">
1159<pre class="literallayout"><span class="keyword">template</span><span class="special">&lt;</span><span class="keyword">typename</span> InputIterator<span class="special">&gt;</span>
1160  <span class="keyword">void</span> <a name="idm46495623835184-bb"></a><span class="identifier">assign</span><span class="special">(</span><span class="identifier">InputIterator</span> first<span class="special">,</span> <span class="identifier">InputIterator</span> last<span class="special">)</span><span class="special">;</span></pre>Assign a copy of the range into the space optimized circular buffer. <p>The content of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> will be removed and replaced with copies of elements from the specified range.
1161
1162
1163
1164</p>
1165<p><b>Exception Safety.&#160;</b>Basic. </p>
1166<p>
1167</p>
1168<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1169<p>
1170</p>
1171<p><b>Complexity.&#160;</b>Linear (in the <code class="computeroutput">std::distance(first, last)</code>). </p>
1172<p>
1173</p>
1174<p><span class="bold"><strong>See Also:</strong></span></p>
1175<p><code class="computeroutput">operator=</code>, <code class="computeroutput">assign(size_type, const_reference)</code>, <code class="computeroutput">assign(capacity_type, size_type, const_reference)</code>, <code class="computeroutput">assign(capacity_type, InputIterator, InputIterator)</code> </p>
1176<p>
1177</p>
1178<p>
1179</p>
1180<div class="variablelist"><table border="0" class="variablelist compact">
1181<colgroup>
1182<col align="left" valign="top">
1183<col>
1184</colgroup>
1185<tbody>
1186<tr>
1187<td><p><span class="term">Parameters:</span></p></td>
1188<td><div class="variablelist"><table border="0" class="variablelist compact">
1189<colgroup>
1190<col align="left" valign="top">
1191<col>
1192</colgroup>
1193<tbody>
1194<tr>
1195<td><p><span class="term"><code class="computeroutput">first</code></span></p></td>
1196<td><p>The beginning of the range to be copied. </p></td>
1197</tr>
1198<tr>
1199<td><p><span class="term"><code class="computeroutput">last</code></span></p></td>
1200<td><p>The end of the range to be copied. </p></td>
1201</tr>
1202</tbody>
1203</table></div></td>
1204</tr>
1205<tr>
1206<td><p><span class="term">Requires:</span></p></td>
1207<td><p>Valid range <code class="computeroutput">[first, last)</code>.<br>
1208 <code class="computeroutput">first</code> and <code class="computeroutput">last</code> have to meet the requirements of <a href="https://www.boost.org/sgi/stl/InputIterator.html" target="_top">InputIterator</a>. </p></td>
1209</tr>
1210<tr>
1211<td><p><span class="term">Postconditions:</span></p></td>
1212<td><p><code class="computeroutput">capacity().capacity() == std::distance(first, last) &amp;&amp; capacity().min_capacity() == 0 &amp;&amp; size() == std::distance(first, last) &amp;&amp; (*this)[0]== *first &amp;&amp; (*this)[1] == *(first + 1) &amp;&amp; ... &amp;&amp; (*this)[std::distance(first, last) - 1] == *(last - 1)</code><br>
1213<br>
1214 The amount of allocated memory in the internal buffer is <code class="computeroutput">std::distance(first, last)</code>. </p></td>
1215</tr>
1216<tr>
1217<td><p><span class="term">Throws:</span></p></td>
1218<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws or nothing if <code class="computeroutput">T::T(T&amp;&amp;)</code> is noexcept and <code class="computeroutput">InputIterator</code> is a move iterator. </td>
1219</tr>
1220</tbody>
1221</table></div>
1222</li>
1223<li class="listitem">
1224<pre class="literallayout"><span class="keyword">template</span><span class="special">&lt;</span><span class="keyword">typename</span> InputIterator<span class="special">&gt;</span>
1225  <span class="keyword">void</span> <a name="idm46495623814080-bb"></a><span class="identifier">assign</span><span class="special">(</span><span class="identifier">capacity_type</span> capacity_ctrl<span class="special">,</span> <span class="identifier">InputIterator</span> first<span class="special">,</span>
1226              <span class="identifier">InputIterator</span> last<span class="special">)</span><span class="special">;</span></pre>Assign a copy of the range into the space optimized circular buffer specifying the capacity. <p>The capacity of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> will be set to the specified value and the content of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> will be removed and replaced with copies of elements from the specified range.
1227
1228
1229
1230</p>
1231<p><b>Exception Safety.&#160;</b>Basic. </p>
1232<p>
1233</p>
1234<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1235<p>
1236</p>
1237<p><b>Complexity.&#160;</b>Linear (in <code class="computeroutput">std::distance(first, last)</code>; in <code class="computeroutput">min[capacity_ctrl.capacity(), std::distance(first, last)]</code> if the <code class="computeroutput">InputIterator</code> is a <a href="https://www.boost.org/sgi/stl/RandomAccessIterator.html" target="_top">RandomAccessIterator</a>). </p>
1238<p>
1239</p>
1240<p><span class="bold"><strong>See Also:</strong></span></p>
1241<p><code class="computeroutput">operator=</code>, <code class="computeroutput">assign(size_type, const_reference)</code>, <code class="computeroutput">assign(capacity_type, size_type, const_reference)</code>, <code class="computeroutput">assign(InputIterator, InputIterator)</code> </p>
1242<p>
1243</p>
1244<p>
1245</p>
1246<div class="variablelist"><table border="0" class="variablelist compact">
1247<colgroup>
1248<col align="left" valign="top">
1249<col>
1250</colgroup>
1251<tbody>
1252<tr>
1253<td><p><span class="term">Parameters:</span></p></td>
1254<td><div class="variablelist"><table border="0" class="variablelist compact">
1255<colgroup>
1256<col align="left" valign="top">
1257<col>
1258</colgroup>
1259<tbody>
1260<tr>
1261<td><p><span class="term"><code class="computeroutput">capacity_ctrl</code></span></p></td>
1262<td><p>The new capacity controller. </p></td>
1263</tr>
1264<tr>
1265<td><p><span class="term"><code class="computeroutput">first</code></span></p></td>
1266<td><p>The beginning of the range to be copied. </p></td>
1267</tr>
1268<tr>
1269<td><p><span class="term"><code class="computeroutput">last</code></span></p></td>
1270<td><p>The end of the range to be copied. </p></td>
1271</tr>
1272</tbody>
1273</table></div></td>
1274</tr>
1275<tr>
1276<td><p><span class="term">Requires:</span></p></td>
1277<td><p>Valid range <code class="computeroutput">[first, last)</code>.<br>
1278 <code class="computeroutput">first</code> and <code class="computeroutput">last</code> have to meet the requirements of <a href="https://www.boost.org/sgi/stl/InputIterator.html" target="_top">InputIterator</a>. </p></td>
1279</tr>
1280<tr>
1281<td><p><span class="term">Postconditions:</span></p></td>
1282<td><p><code class="computeroutput">capacity() == capacity_ctrl &amp;&amp; size() &lt;= std::distance(first, last) &amp;&amp; (*this)[0]== *(last - capacity) &amp;&amp; (*this)[1] == *(last - capacity + 1) &amp;&amp; ... &amp;&amp; (*this)[capacity - 1] == *(last - 1)</code><br>
1283<br>
1284 If the number of items to be copied from the range <code class="computeroutput">[first, last)</code> is greater than the specified <code class="computeroutput">capacity</code> then only elements from the range <code class="computeroutput">[last - capacity, last)</code> will be copied.<br>
1285<br>
1286 The amount of allocated memory in the internal buffer is <code class="computeroutput">max[std::distance(first, last), capacity_ctrl.min_capacity()]</code>. </p></td>
1287</tr>
1288<tr>
1289<td><p><span class="term">Throws:</span></p></td>
1290<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws or nothing if <code class="computeroutput">T::T(T&amp;&amp;)</code> is noexcept and <code class="computeroutput">InputIterator</code> is a move iterator. </td>
1291</tr>
1292</tbody>
1293</table></div>
1294</li>
1295<li class="listitem">
1296<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623787248-bb"></a><span class="identifier">swap</span><span class="special">(</span><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a><span class="special">&lt;</span> <span class="identifier">T</span><span class="special">,</span> <span class="identifier">Alloc</span> <span class="special">&gt;</span> <span class="special">&amp;</span> cb<span class="special">)</span> <span class="keyword">noexcept</span><span class="special">;</span></pre>Swap the contents of two space-optimized circular-buffers. <p>
1297
1298
1299</p>
1300<p><b>Exception Safety.&#160;</b>No-throw. </p>
1301<p>
1302</p>
1303<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators of both <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> containers. (On the other hand the iterators still point to the same elements but within another container. If you want to rely on this feature you have to turn the __debug_support off, otherwise an assertion will report an error if such invalidated iterator is used.) </p>
1304<p>
1305</p>
1306<p><b>Complexity.&#160;</b>Constant (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
1307<p>
1308</p>
1309<p><span class="bold"><strong>See Also:</strong></span></p>
1310<p><code class="computeroutput">swap(circular_buffer&lt;T, Alloc&gt;&amp;, circular_buffer&lt;T, Alloc&gt;&amp;)</code>, <code class="computeroutput">swap(circular_buffer_space_optimized&lt;T, Alloc&gt;&amp;, circular_buffer_space_optimized&lt;T, Alloc&gt;&amp;)</code> </p>
1311<p>
1312</p>
1313<p>
1314</p>
1315<div class="variablelist"><table border="0" class="variablelist compact">
1316<colgroup>
1317<col align="left" valign="top">
1318<col>
1319</colgroup>
1320<tbody>
1321<tr>
1322<td><p><span class="term">Parameters:</span></p></td>
1323<td><div class="variablelist"><table border="0" class="variablelist compact">
1324<colgroup>
1325<col align="left" valign="top">
1326<col>
1327</colgroup>
1328<tbody><tr>
1329<td><p><span class="term"><code class="computeroutput">cb</code></span></p></td>
1330<td><p>The <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> whose content will be swapped. </p></td>
1331</tr></tbody>
1332</table></div></td>
1333</tr>
1334<tr>
1335<td><p><span class="term">Postconditions:</span></p></td>
1336<td><p><code class="computeroutput">this</code> contains elements of <code class="computeroutput">cb</code> and vice versa; the capacity and the amount of allocated memory in the internal buffer of <code class="computeroutput">this</code> equal to the capacity and the amount of allocated memory of <code class="computeroutput">cb</code> and vice versa. </p></td>
1337</tr>
1338<tr>
1339<td><p><span class="term">Throws:</span></p></td>
1340<td>Nothing. </td>
1341</tr>
1342</tbody>
1343</table></div>
1344</li>
1345<li class="listitem">
1346<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623772752-bb"></a><span class="identifier">push_back</span><span class="special">(</span><span class="identifier">param_value_type</span> item<span class="special">)</span><span class="special">;</span></pre>Insert a new element at the end of the space optimized circular buffer. <p>
1347
1348
1349</p>
1350<p><b>Exception Safety.&#160;</b>Basic. </p>
1351<p>
1352</p>
1353<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1354<p>
1355</p>
1356<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
1357<p>
1358</p>
1359<p><span class="bold"><strong>See Also:</strong></span></p>
1360<p><code class="computeroutput">push_front(const_reference)</code>, <code class="computeroutput">pop_back()</code>, <code class="computeroutput">pop_front()</code> </p>
1361<p>
1362</p>
1363<p>
1364</p>
1365<div class="variablelist"><table border="0" class="variablelist compact">
1366<colgroup>
1367<col align="left" valign="top">
1368<col>
1369</colgroup>
1370<tbody>
1371<tr>
1372<td><p><span class="term">Parameters:</span></p></td>
1373<td><div class="variablelist"><table border="0" class="variablelist compact">
1374<colgroup>
1375<col align="left" valign="top">
1376<col>
1377</colgroup>
1378<tbody><tr>
1379<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
1380<td><p>The element to be inserted. </p></td>
1381</tr></tbody>
1382</table></div></td>
1383</tr>
1384<tr>
1385<td><p><span class="term">Postconditions:</span></p></td>
1386<td><p>if <code class="computeroutput">capacity().capacity() &gt; 0</code> then <code class="computeroutput">back() == item</code><br>
1387 If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full, the first element will be removed. If the capacity is <code class="computeroutput">0</code>, nothing will be inserted.<br>
1388<br>
1389 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
1390</tr>
1391<tr>
1392<td><p><span class="term">Throws:</span></p></td>
1393<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws. </td>
1394</tr>
1395</tbody>
1396</table></div>
1397</li>
1398<li class="listitem">
1399<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623756880-bb"></a><span class="identifier">push_back</span><span class="special">(</span><span class="identifier">rvalue_type</span> item<span class="special">)</span><span class="special">;</span></pre>Insert a new element at the end of the space optimized circular buffer. <p>
1400
1401
1402</p>
1403<p><b>Exception Safety.&#160;</b>Basic. </p>
1404<p>
1405</p>
1406<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1407<p>
1408</p>
1409<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
1410<p>
1411</p>
1412<p><span class="bold"><strong>See Also:</strong></span></p>
1413<p><code class="computeroutput">push_front(const_reference)</code>, <code class="computeroutput">pop_back()</code>, <code class="computeroutput">pop_front()</code> </p>
1414<p>
1415</p>
1416<p>
1417</p>
1418<div class="variablelist"><table border="0" class="variablelist compact">
1419<colgroup>
1420<col align="left" valign="top">
1421<col>
1422</colgroup>
1423<tbody>
1424<tr>
1425<td><p><span class="term">Parameters:</span></p></td>
1426<td><div class="variablelist"><table border="0" class="variablelist compact">
1427<colgroup>
1428<col align="left" valign="top">
1429<col>
1430</colgroup>
1431<tbody><tr>
1432<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
1433<td><p>The element to be inserted. </p></td>
1434</tr></tbody>
1435</table></div></td>
1436</tr>
1437<tr>
1438<td><p><span class="term">Postconditions:</span></p></td>
1439<td><p>if <code class="computeroutput">capacity().capacity() &gt; 0</code> then <code class="computeroutput">back() == item</code><br>
1440 If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full, the first element will be removed. If the capacity is <code class="computeroutput">0</code>, nothing will be inserted.<br>
1441<br>
1442 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
1443</tr>
1444<tr>
1445<td><p><span class="term">Throws:</span></p></td>
1446<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). </td>
1447</tr>
1448</tbody>
1449</table></div>
1450</li>
1451<li class="listitem">
1452<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623741472-bb"></a><span class="identifier">push_back</span><span class="special">(</span><span class="special">)</span><span class="special">;</span></pre>Insert a new element at the end of the space optimized circular buffer. <p>
1453
1454</p>
1455<p><b>Exception Safety.&#160;</b>Basic. </p>
1456<p>
1457</p>
1458<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1459<p>
1460</p>
1461<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
1462<p>
1463</p>
1464<p><span class="bold"><strong>See Also:</strong></span></p>
1465<p><code class="computeroutput">push_front(const_reference)</code>, <code class="computeroutput">pop_back()</code>, <code class="computeroutput">pop_front()</code> </p>
1466<p>
1467</p>
1468<p>
1469</p>
1470<div class="variablelist"><table border="0" class="variablelist compact">
1471<colgroup>
1472<col align="left" valign="top">
1473<col>
1474</colgroup>
1475<tbody>
1476<tr>
1477<td><p><span class="term">Postconditions:</span></p></td>
1478<td><p>if <code class="computeroutput">capacity().capacity() &gt; 0</code> then <code class="computeroutput">back() == item</code><br>
1479 If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full, the first element will be removed. If the capacity is <code class="computeroutput">0</code>, nothing will be inserted.<br>
1480<br>
1481 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
1482</tr>
1483<tr>
1484<td><p><span class="term">Throws:</span></p></td>
1485<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T()</code> throws. Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws or nothing if <code class="computeroutput">T::T(T&amp;&amp;)</code> is noexcept. </td>
1486</tr>
1487</tbody>
1488</table></div>
1489</li>
1490<li class="listitem">
1491<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623725824-bb"></a><span class="identifier">push_front</span><span class="special">(</span><span class="identifier">param_value_type</span> item<span class="special">)</span><span class="special">;</span></pre>Insert a new element at the beginning of the space optimized circular buffer. <p>
1492
1493
1494</p>
1495<p><b>Exception Safety.&#160;</b>Basic. </p>
1496<p>
1497</p>
1498<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1499<p>
1500</p>
1501<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
1502<p>
1503</p>
1504<p><span class="bold"><strong>See Also:</strong></span></p>
1505<p><code class="computeroutput">push_back(const_reference)</code>, <code class="computeroutput">pop_back()</code>, <code class="computeroutput">pop_front()</code> </p>
1506<p>
1507</p>
1508<p>
1509</p>
1510<div class="variablelist"><table border="0" class="variablelist compact">
1511<colgroup>
1512<col align="left" valign="top">
1513<col>
1514</colgroup>
1515<tbody>
1516<tr>
1517<td><p><span class="term">Parameters:</span></p></td>
1518<td><div class="variablelist"><table border="0" class="variablelist compact">
1519<colgroup>
1520<col align="left" valign="top">
1521<col>
1522</colgroup>
1523<tbody><tr>
1524<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
1525<td><p>The element to be inserted. </p></td>
1526</tr></tbody>
1527</table></div></td>
1528</tr>
1529<tr>
1530<td><p><span class="term">Postconditions:</span></p></td>
1531<td><p>if <code class="computeroutput">capacity().capacity() &gt; 0</code> then <code class="computeroutput">front() == item</code><br>
1532 If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full, the last element will be removed. If the capacity is <code class="computeroutput">0</code>, nothing will be inserted.<br>
1533<br>
1534 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
1535</tr>
1536<tr>
1537<td><p><span class="term">Throws:</span></p></td>
1538<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws. </td>
1539</tr>
1540</tbody>
1541</table></div>
1542</li>
1543<li class="listitem">
1544<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623709952-bb"></a><span class="identifier">push_front</span><span class="special">(</span><span class="identifier">rvalue_type</span> item<span class="special">)</span><span class="special">;</span></pre>Insert a new element at the beginning of the space optimized circular buffer. <p>
1545
1546
1547</p>
1548<p><b>Exception Safety.&#160;</b>Basic. </p>
1549<p>
1550</p>
1551<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1552<p>
1553</p>
1554<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
1555<p>
1556</p>
1557<p><span class="bold"><strong>See Also:</strong></span></p>
1558<p><code class="computeroutput">push_back(const_reference)</code>, <code class="computeroutput">pop_back()</code>, <code class="computeroutput">pop_front()</code> </p>
1559<p>
1560</p>
1561<p>
1562</p>
1563<div class="variablelist"><table border="0" class="variablelist compact">
1564<colgroup>
1565<col align="left" valign="top">
1566<col>
1567</colgroup>
1568<tbody>
1569<tr>
1570<td><p><span class="term">Parameters:</span></p></td>
1571<td><div class="variablelist"><table border="0" class="variablelist compact">
1572<colgroup>
1573<col align="left" valign="top">
1574<col>
1575</colgroup>
1576<tbody><tr>
1577<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
1578<td><p>The element to be inserted. </p></td>
1579</tr></tbody>
1580</table></div></td>
1581</tr>
1582<tr>
1583<td><p><span class="term">Postconditions:</span></p></td>
1584<td><p>if <code class="computeroutput">capacity().capacity() &gt; 0</code> then <code class="computeroutput">front() == item</code><br>
1585 If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full, the last element will be removed. If the capacity is <code class="computeroutput">0</code>, nothing will be inserted.<br>
1586<br>
1587 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
1588</tr>
1589<tr>
1590<td><p><span class="term">Throws:</span></p></td>
1591<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws or nothing if <code class="computeroutput">T::T(T&amp;&amp;)</code> is noexcept. </td>
1592</tr>
1593</tbody>
1594</table></div>
1595</li>
1596<li class="listitem">
1597<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623693632-bb"></a><span class="identifier">push_front</span><span class="special">(</span><span class="special">)</span><span class="special">;</span></pre>Insert a new element at the beginning of the space optimized circular buffer. <p>
1598
1599</p>
1600<p><b>Exception Safety.&#160;</b>Basic. </p>
1601<p>
1602</p>
1603<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1604<p>
1605</p>
1606<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
1607<p>
1608</p>
1609<p><span class="bold"><strong>See Also:</strong></span></p>
1610<p><code class="computeroutput">push_back(const_reference)</code>, <code class="computeroutput">pop_back()</code>, <code class="computeroutput">pop_front()</code> </p>
1611<p>
1612</p>
1613<p>
1614</p>
1615<div class="variablelist"><table border="0" class="variablelist compact">
1616<colgroup>
1617<col align="left" valign="top">
1618<col>
1619</colgroup>
1620<tbody>
1621<tr>
1622<td><p><span class="term">Postconditions:</span></p></td>
1623<td><p>if <code class="computeroutput">capacity().capacity() &gt; 0</code> then <code class="computeroutput">front() == item</code><br>
1624 If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full, the last element will be removed. If the capacity is <code class="computeroutput">0</code>, nothing will be inserted.<br>
1625<br>
1626 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
1627</tr>
1628<tr>
1629<td><p><span class="term">Throws:</span></p></td>
1630<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T()</code> throws. Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws or nothing if <code class="computeroutput">T::T(T&amp;&amp;)</code> is noexcept. </td>
1631</tr>
1632</tbody>
1633</table></div>
1634</li>
1635<li class="listitem">
1636<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623677984-bb"></a><span class="identifier">pop_back</span><span class="special">(</span><span class="special">)</span><span class="special">;</span></pre>Remove the last element from the space optimized circular buffer. <p>
1637
1638
1639</p>
1640<p><b>Exception Safety.&#160;</b>Basic. </p>
1641<p>
1642</p>
1643<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1644<p>
1645</p>
1646<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
1647<p>
1648</p>
1649<p><span class="bold"><strong>See Also:</strong></span></p>
1650<p><code class="computeroutput">pop_front()</code>, <code class="computeroutput">push_back(const_reference)</code>, <code class="computeroutput">push_front(const_reference)</code> </p>
1651<p>
1652</p>
1653<p>
1654</p>
1655<div class="variablelist"><table border="0" class="variablelist compact">
1656<colgroup>
1657<col align="left" valign="top">
1658<col>
1659</colgroup>
1660<tbody>
1661<tr>
1662<td><p><span class="term">Requires:</span></p></td>
1663<td><p><code class="computeroutput">!empty()</code> </p></td>
1664</tr>
1665<tr>
1666<td><p><span class="term">Postconditions:</span></p></td>
1667<td><p>The last element is removed from the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code>.<br>
1668<br>
1669 The amount of allocated memory in the internal buffer may be predictively decreased. </p></td>
1670</tr>
1671<tr>
1672<td><p><span class="term">Throws:</span></p></td>
1673<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). </td>
1674</tr>
1675</tbody>
1676</table></div>
1677</li>
1678<li class="listitem">
1679<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623664368-bb"></a><span class="identifier">pop_front</span><span class="special">(</span><span class="special">)</span><span class="special">;</span></pre>Remove the first element from the space optimized circular buffer. <p>
1680
1681
1682</p>
1683<p><b>Exception Safety.&#160;</b>Basic. </p>
1684<p>
1685</p>
1686<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1687<p>
1688</p>
1689<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
1690<p>
1691</p>
1692<p><span class="bold"><strong>See Also:</strong></span></p>
1693<p><code class="computeroutput">pop_back()</code>, <code class="computeroutput">push_back(const_reference)</code>, <code class="computeroutput">push_front(const_reference)</code> </p>
1694<p>
1695</p>
1696<p>
1697</p>
1698<div class="variablelist"><table border="0" class="variablelist compact">
1699<colgroup>
1700<col align="left" valign="top">
1701<col>
1702</colgroup>
1703<tbody>
1704<tr>
1705<td><p><span class="term">Requires:</span></p></td>
1706<td><p><code class="computeroutput">!empty()</code> </p></td>
1707</tr>
1708<tr>
1709<td><p><span class="term">Postconditions:</span></p></td>
1710<td><p>The first element is removed from the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code>.<br>
1711<br>
1712 The amount of allocated memory in the internal buffer may be predictively decreased. </p></td>
1713</tr>
1714<tr>
1715<td><p><span class="term">Throws:</span></p></td>
1716<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). </td>
1717</tr>
1718</tbody>
1719</table></div>
1720</li>
1721<li class="listitem">
1722<pre class="literallayout"><span class="identifier">iterator</span> <a name="idm46495623650752-bb"></a><span class="identifier">insert</span><span class="special">(</span><span class="identifier">iterator</span> pos<span class="special">,</span> <span class="identifier">param_value_type</span> item<span class="special">)</span><span class="special">;</span></pre>Insert an element at the specified position. <p>
1723
1724
1725
1726
1727</p>
1728<p><b>Exception Safety.&#160;</b>Basic. </p>
1729<p>
1730</p>
1731<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1732<p>
1733</p>
1734<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
1735<p>
1736</p>
1737<p><span class="bold"><strong>See Also:</strong></span></p>
1738<p><code class="computeroutput">insert(iterator, size_type, value_type)</code>, <code class="computeroutput">insert(iterator, InputIterator, InputIterator)</code>, <code class="computeroutput">rinsert(iterator, value_type)</code>, <code class="computeroutput">rinsert(iterator, size_type, value_type)</code>, <code class="computeroutput">rinsert(iterator, InputIterator, InputIterator)</code> </p>
1739<p>
1740</p>
1741<p>
1742</p>
1743<div class="variablelist"><table border="0" class="variablelist compact">
1744<colgroup>
1745<col align="left" valign="top">
1746<col>
1747</colgroup>
1748<tbody>
1749<tr>
1750<td><p><span class="term">Parameters:</span></p></td>
1751<td><div class="variablelist"><table border="0" class="variablelist compact">
1752<colgroup>
1753<col align="left" valign="top">
1754<col>
1755</colgroup>
1756<tbody>
1757<tr>
1758<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
1759<td><p>The element to be inserted. </p></td>
1760</tr>
1761<tr>
1762<td><p><span class="term"><code class="computeroutput">pos</code></span></p></td>
1763<td><p>An iterator specifying the position where the <code class="computeroutput">item</code> will be inserted. </p></td>
1764</tr>
1765</tbody>
1766</table></div></td>
1767</tr>
1768<tr>
1769<td><p><span class="term">Requires:</span></p></td>
1770<td><p><code class="computeroutput">pos</code> is a valid iterator pointing to the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> or its end. </p></td>
1771</tr>
1772<tr>
1773<td><p><span class="term">Postconditions:</span></p></td>
1774<td><p>The <code class="computeroutput">item</code> will be inserted at the position <code class="computeroutput">pos</code>.<br>
1775 If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full, the first element will be overwritten. If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full and the <code class="computeroutput">pos</code> points to <code class="computeroutput">begin()</code>, then the <code class="computeroutput">item</code> will not be inserted. If the capacity is <code class="computeroutput">0</code>, nothing will be inserted.<br>
1776<br>
1777 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
1778</tr>
1779<tr>
1780<td><p><span class="term">Returns:</span></p></td>
1781<td><p>Iterator to the inserted element or <code class="computeroutput">begin()</code> if the <code class="computeroutput">item</code> is not inserted. (See the <span class="emphasis"><em>Effect</em></span>.) </p></td>
1782</tr>
1783<tr>
1784<td><p><span class="term">Throws:</span></p></td>
1785<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws. Whatever <code class="computeroutput">T::operator = (const T&amp;)</code> throws. </td>
1786</tr>
1787</tbody>
1788</table></div>
1789</li>
1790<li class="listitem">
1791<pre class="literallayout"><span class="identifier">iterator</span> <a name="idm46495623625728-bb"></a><span class="identifier">insert</span><span class="special">(</span><span class="identifier">iterator</span> pos<span class="special">,</span> <span class="identifier">rvalue_type</span> item<span class="special">)</span><span class="special">;</span></pre>Insert an element at the specified position. <p>
1792
1793
1794
1795
1796</p>
1797<p><b>Exception Safety.&#160;</b>Basic. </p>
1798<p>
1799</p>
1800<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1801<p>
1802</p>
1803<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
1804<p>
1805</p>
1806<p><span class="bold"><strong>See Also:</strong></span></p>
1807<p><code class="computeroutput">insert(iterator, size_type, value_type)</code>, <code class="computeroutput">insert(iterator, InputIterator, InputIterator)</code>, <code class="computeroutput">rinsert(iterator, value_type)</code>, <code class="computeroutput">rinsert(iterator, size_type, value_type)</code>, <code class="computeroutput">rinsert(iterator, InputIterator, InputIterator)</code> </p>
1808<p>
1809</p>
1810<p>
1811</p>
1812<div class="variablelist"><table border="0" class="variablelist compact">
1813<colgroup>
1814<col align="left" valign="top">
1815<col>
1816</colgroup>
1817<tbody>
1818<tr>
1819<td><p><span class="term">Parameters:</span></p></td>
1820<td><div class="variablelist"><table border="0" class="variablelist compact">
1821<colgroup>
1822<col align="left" valign="top">
1823<col>
1824</colgroup>
1825<tbody>
1826<tr>
1827<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
1828<td><p>The element to be inserted. </p></td>
1829</tr>
1830<tr>
1831<td><p><span class="term"><code class="computeroutput">pos</code></span></p></td>
1832<td><p>An iterator specifying the position where the <code class="computeroutput">item</code> will be inserted. </p></td>
1833</tr>
1834</tbody>
1835</table></div></td>
1836</tr>
1837<tr>
1838<td><p><span class="term">Requires:</span></p></td>
1839<td><p><code class="computeroutput">pos</code> is a valid iterator pointing to the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> or its end. </p></td>
1840</tr>
1841<tr>
1842<td><p><span class="term">Postconditions:</span></p></td>
1843<td><p>The <code class="computeroutput">item</code> will be inserted at the position <code class="computeroutput">pos</code>.<br>
1844 If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full, the first element will be overwritten. If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full and the <code class="computeroutput">pos</code> points to <code class="computeroutput">begin()</code>, then the <code class="computeroutput">item</code> will not be inserted. If the capacity is <code class="computeroutput">0</code>, nothing will be inserted.<br>
1845<br>
1846 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
1847</tr>
1848<tr>
1849<td><p><span class="term">Returns:</span></p></td>
1850<td><p>Iterator to the inserted element or <code class="computeroutput">begin()</code> if the <code class="computeroutput">item</code> is not inserted. (See the <span class="emphasis"><em>Effect</em></span>.) </p></td>
1851</tr>
1852<tr>
1853<td><p><span class="term">Throws:</span></p></td>
1854<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws or nothing if <code class="computeroutput">T::T(T&amp;&amp;)</code> is noexcept. </td>
1855</tr>
1856</tbody>
1857</table></div>
1858</li>
1859<li class="listitem">
1860<pre class="literallayout"><span class="identifier">iterator</span> <a name="idm46495623600720-bb"></a><span class="identifier">insert</span><span class="special">(</span><span class="identifier">iterator</span> pos<span class="special">)</span><span class="special">;</span></pre>Insert an element at the specified position. <p>
1861
1862
1863
1864
1865</p>
1866<p><b>Exception Safety.&#160;</b>Basic. </p>
1867<p>
1868</p>
1869<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1870<p>
1871</p>
1872<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
1873<p>
1874</p>
1875<p><span class="bold"><strong>See Also:</strong></span></p>
1876<p><code class="computeroutput">insert(iterator, size_type, value_type)</code>, <code class="computeroutput">insert(iterator, InputIterator, InputIterator)</code>, <code class="computeroutput">rinsert(iterator, value_type)</code>, <code class="computeroutput">rinsert(iterator, size_type, value_type)</code>, <code class="computeroutput">rinsert(iterator, InputIterator, InputIterator)</code> </p>
1877<p>
1878</p>
1879<p>
1880</p>
1881<div class="variablelist"><table border="0" class="variablelist compact">
1882<colgroup>
1883<col align="left" valign="top">
1884<col>
1885</colgroup>
1886<tbody>
1887<tr>
1888<td><p><span class="term">Parameters:</span></p></td>
1889<td><div class="variablelist"><table border="0" class="variablelist compact">
1890<colgroup>
1891<col align="left" valign="top">
1892<col>
1893</colgroup>
1894<tbody><tr>
1895<td><p><span class="term"><code class="computeroutput">pos</code></span></p></td>
1896<td><p>An iterator specifying the position where the <code class="computeroutput">item</code> will be inserted. </p></td>
1897</tr></tbody>
1898</table></div></td>
1899</tr>
1900<tr>
1901<td><p><span class="term">Requires:</span></p></td>
1902<td><p><code class="computeroutput">pos</code> is a valid iterator pointing to the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> or its end. </p></td>
1903</tr>
1904<tr>
1905<td><p><span class="term">Postconditions:</span></p></td>
1906<td><p>The <code class="computeroutput">item</code> will be inserted at the position <code class="computeroutput">pos</code>.<br>
1907 If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full, the first element will be overwritten. If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full and the <code class="computeroutput">pos</code> points to <code class="computeroutput">begin()</code>, then the <code class="computeroutput">item</code> will not be inserted. If the capacity is <code class="computeroutput">0</code>, nothing will be inserted.<br>
1908<br>
1909 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
1910</tr>
1911<tr>
1912<td><p><span class="term">Returns:</span></p></td>
1913<td><p>Iterator to the inserted element or <code class="computeroutput">begin()</code> if the <code class="computeroutput">item</code> is not inserted. (See the <span class="emphasis"><em>Effect</em></span>.) </p></td>
1914</tr>
1915<tr>
1916<td><p><span class="term">Throws:</span></p></td>
1917<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T()</code> throws. Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws or nothing if <code class="computeroutput">T::T(T&amp;&amp;)</code> is noexcept. </td>
1918</tr>
1919</tbody>
1920</table></div>
1921</li>
1922<li class="listitem">
1923<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623576384-bb"></a><span class="identifier">insert</span><span class="special">(</span><span class="identifier">iterator</span> pos<span class="special">,</span> <span class="identifier">size_type</span> n<span class="special">,</span> <span class="identifier">param_value_type</span> item<span class="special">)</span><span class="special">;</span></pre>Insert <code class="computeroutput">n</code> copies of the <code class="computeroutput">item</code> at the specified position. <p>
1924
1925
1926
1927</p>
1928<p><b>Exception Safety.&#160;</b>Basic. </p>
1929<p>
1930</p>
1931<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
1932<p>
1933</p>
1934<p><b>Complexity.&#160;</b>Linear (in <code class="computeroutput">min[capacity().capacity(), size() + n]</code>). </p>
1935<p>
1936</p>
1937<p><b>Example.&#160;</b>Consider a <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> with the capacity of 6 and the size of 4. Its internal buffer may look like the one below.<br>
1938<br>
1939 <code class="computeroutput">|1|2|3|4| | |</code><br>
1940 <code class="computeroutput">p ___^</code><br>
1941<br>
1942After inserting 5 elements at the position <code class="computeroutput">p</code>:<br>
1943<br>
1944 <code class="computeroutput">insert(p, (size_t)5, 0);</code><br>
1945<br>
1946actually only 4 elements get inserted and elements <code class="computeroutput">1</code> and <code class="computeroutput">2</code> are overwritten. This is due to the fact the insert operation preserves the capacity. After insertion the internal buffer looks like this:<br>
1947<br>
1948<code class="computeroutput">|0|0|0|0|3|4|</code><br>
1949 <br>
1950For comparison if the capacity would not be preserved the internal buffer would then result in <code class="computeroutput">|1|2|0|0|0|0|0|3|4|</code>. </p>
1951<p>
1952</p>
1953<p><span class="bold"><strong>See Also:</strong></span></p>
1954<p><code class="computeroutput">insert(iterator, value_type)</code>, <code class="computeroutput">insert(iterator, InputIterator, InputIterator)</code>, <code class="computeroutput">rinsert(iterator, value_type)</code>, <code class="computeroutput">rinsert(iterator, size_type, value_type)</code>, <code class="computeroutput">rinsert(iterator, InputIterator, InputIterator)</code> </p>
1955<p>
1956</p>
1957<p>
1958</p>
1959<div class="variablelist"><table border="0" class="variablelist compact">
1960<colgroup>
1961<col align="left" valign="top">
1962<col>
1963</colgroup>
1964<tbody>
1965<tr>
1966<td><p><span class="term">Parameters:</span></p></td>
1967<td><div class="variablelist"><table border="0" class="variablelist compact">
1968<colgroup>
1969<col align="left" valign="top">
1970<col>
1971</colgroup>
1972<tbody>
1973<tr>
1974<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
1975<td><p>The element whose copies will be inserted. </p></td>
1976</tr>
1977<tr>
1978<td><p><span class="term"><code class="computeroutput">n</code></span></p></td>
1979<td><p>The number of <code class="computeroutput">item</code>s the to be inserted. </p></td>
1980</tr>
1981<tr>
1982<td><p><span class="term"><code class="computeroutput">pos</code></span></p></td>
1983<td><p>An iterator specifying the position where the <code class="computeroutput">item</code>s will be inserted. </p></td>
1984</tr>
1985</tbody>
1986</table></div></td>
1987</tr>
1988<tr>
1989<td><p><span class="term">Requires:</span></p></td>
1990<td><p><code class="computeroutput">pos</code> is a valid iterator pointing to the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> or its end. </p></td>
1991</tr>
1992<tr>
1993<td><p><span class="term">Postconditions:</span></p></td>
1994<td><p>The number of <code class="computeroutput">min[n, (pos - begin()) + reserve()]</code> elements will be inserted at the position <code class="computeroutput">pos</code>.<br>
1995The number of <code class="computeroutput">min[pos - begin(), max[0, n - reserve()]]</code> elements will be overwritten at the beginning of the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code>.<br>
1996(See <span class="emphasis"><em>Example</em></span> for the explanation.)<br>
1997<br>
1998 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
1999</tr>
2000<tr>
2001<td><p><span class="term">Throws:</span></p></td>
2002<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws. Whatever <code class="computeroutput">T::operator = (const T&amp;)</code> throws. </td>
2003</tr>
2004</tbody>
2005</table></div>
2006</li>
2007<li class="listitem">
2008<pre class="literallayout"><span class="keyword">template</span><span class="special">&lt;</span><span class="keyword">typename</span> InputIterator<span class="special">&gt;</span>
2009  <span class="keyword">void</span> <a name="idm46495623543824-bb"></a><span class="identifier">insert</span><span class="special">(</span><span class="identifier">iterator</span> pos<span class="special">,</span> <span class="identifier">InputIterator</span> first<span class="special">,</span> <span class="identifier">InputIterator</span> last<span class="special">)</span><span class="special">;</span></pre>Insert the range <code class="computeroutput">[first, last)</code> at the specified position. <p>
2010
2011
2012
2013</p>
2014<p><b>Exception Safety.&#160;</b>Basic. </p>
2015<p>
2016</p>
2017<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
2018<p>
2019</p>
2020<p><b>Complexity.&#160;</b>Linear (in <code class="computeroutput">[size() + std::distance(first, last)]</code>; in <code class="computeroutput">min[capacity().capacity(), size() + std::distance(first, last)]</code> if the <code class="computeroutput">InputIterator</code> is a <a href="https://www.boost.org/sgi/stl/RandomAccessIterator.html" target="_top">RandomAccessIterator</a>). </p>
2021<p>
2022</p>
2023<p><b>Example.&#160;</b>Consider a <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> with the capacity of 6 and the size of 4. Its internal buffer may look like the one below.<br>
2024<br>
2025 <code class="computeroutput">|1|2|3|4| | |</code><br>
2026 <code class="computeroutput">p ___^</code><br>
2027<br>
2028After inserting a range of elements at the position <code class="computeroutput">p</code>:<br>
2029<br>
2030 <code class="computeroutput">int array[] = { 5, 6, 7, 8, 9 };</code><br>
2031<code class="computeroutput">insert(p, array, array + 5);</code><br>
2032<br>
2033 actually only elements <code class="computeroutput">6</code>, <code class="computeroutput">7</code>, <code class="computeroutput">8</code> and <code class="computeroutput">9</code> from the specified range get inserted and elements <code class="computeroutput">1</code> and <code class="computeroutput">2</code> are overwritten. This is due to the fact the insert operation preserves the capacity. After insertion the internal buffer looks like this:<br>
2034<br>
2035<code class="computeroutput">|6|7|8|9|3|4|</code><br>
2036<br>
2037For comparison if the capacity would not be preserved the internal buffer would then result in <code class="computeroutput">|1|2|5|6|7|8|9|3|4|</code>. </p>
2038<p>
2039</p>
2040<p><span class="bold"><strong>See Also:</strong></span></p>
2041<p><code class="computeroutput">insert(iterator, value_type)</code>, <code class="computeroutput">insert(iterator, size_type, value_type)</code>, <code class="computeroutput">rinsert(iterator, value_type)</code>, <code class="computeroutput">rinsert(iterator, size_type, value_type)</code>, <code class="computeroutput">rinsert(iterator, InputIterator, InputIterator)</code> </p>
2042<p>
2043</p>
2044<p>
2045</p>
2046<div class="variablelist"><table border="0" class="variablelist compact">
2047<colgroup>
2048<col align="left" valign="top">
2049<col>
2050</colgroup>
2051<tbody>
2052<tr>
2053<td><p><span class="term">Parameters:</span></p></td>
2054<td><div class="variablelist"><table border="0" class="variablelist compact">
2055<colgroup>
2056<col align="left" valign="top">
2057<col>
2058</colgroup>
2059<tbody>
2060<tr>
2061<td><p><span class="term"><code class="computeroutput">first</code></span></p></td>
2062<td><p>The beginning of the range to be inserted. </p></td>
2063</tr>
2064<tr>
2065<td><p><span class="term"><code class="computeroutput">last</code></span></p></td>
2066<td><p>The end of the range to be inserted. </p></td>
2067</tr>
2068<tr>
2069<td><p><span class="term"><code class="computeroutput">pos</code></span></p></td>
2070<td><p>An iterator specifying the position where the range will be inserted. </p></td>
2071</tr>
2072</tbody>
2073</table></div></td>
2074</tr>
2075<tr>
2076<td><p><span class="term">Requires:</span></p></td>
2077<td><p><code class="computeroutput">pos</code> is a valid iterator pointing to the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> or its end.<br>
2078Valid range <code class="computeroutput">[first, last)</code> where <code class="computeroutput">first</code> and <code class="computeroutput">last</code> meet the requirements of an <a href="https://www.boost.org/sgi/stl/InputIterator.html" target="_top">InputIterator</a>. </p></td>
2079</tr>
2080<tr>
2081<td><p><span class="term">Postconditions:</span></p></td>
2082<td><p>Elements from the range <code class="computeroutput">[first + max[0, distance(first, last) - (pos - begin()) - reserve()], last)</code> will be inserted at the position <code class="computeroutput">pos</code>.<br>
2083The number of <code class="computeroutput">min[pos - begin(), max[0, distance(first, last) - reserve()]]</code> elements will be overwritten at the beginning of the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code>.<br>
2084(See <span class="emphasis"><em>Example</em></span> for the explanation.)<br>
2085<br>
2086 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
2087</tr>
2088<tr>
2089<td><p><span class="term">Throws:</span></p></td>
2090<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws or nothing if <code class="computeroutput">T::T(T&amp;&amp;)</code> is noexcept. </td>
2091</tr>
2092</tbody>
2093</table></div>
2094</li>
2095<li class="listitem">
2096<pre class="literallayout"><span class="identifier">iterator</span> <a name="idm46495623505200-bb"></a><span class="identifier">rinsert</span><span class="special">(</span><span class="identifier">iterator</span> pos<span class="special">,</span> <span class="identifier">param_value_type</span> item<span class="special">)</span><span class="special">;</span></pre>Insert an element before the specified position. <p>
2097
2098
2099
2100
2101</p>
2102<p><b>Exception Safety.&#160;</b>Basic. </p>
2103<p>
2104</p>
2105<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
2106<p>
2107</p>
2108<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
2109<p>
2110</p>
2111<p><span class="bold"><strong>See Also:</strong></span></p>
2112<p><code class="computeroutput">rinsert(iterator, size_type, value_type)</code>, <code class="computeroutput">rinsert(iterator, InputIterator, InputIterator)</code>, <code class="computeroutput">insert(iterator, value_type)</code>, <code class="computeroutput">insert(iterator, size_type, value_type)</code>, <code class="computeroutput">insert(iterator, InputIterator, InputIterator)</code> </p>
2113<p>
2114</p>
2115<p>
2116</p>
2117<div class="variablelist"><table border="0" class="variablelist compact">
2118<colgroup>
2119<col align="left" valign="top">
2120<col>
2121</colgroup>
2122<tbody>
2123<tr>
2124<td><p><span class="term">Parameters:</span></p></td>
2125<td><div class="variablelist"><table border="0" class="variablelist compact">
2126<colgroup>
2127<col align="left" valign="top">
2128<col>
2129</colgroup>
2130<tbody>
2131<tr>
2132<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
2133<td><p>The element to be inserted. </p></td>
2134</tr>
2135<tr>
2136<td><p><span class="term"><code class="computeroutput">pos</code></span></p></td>
2137<td><p>An iterator specifying the position before which the <code class="computeroutput">item</code> will be inserted. </p></td>
2138</tr>
2139</tbody>
2140</table></div></td>
2141</tr>
2142<tr>
2143<td><p><span class="term">Requires:</span></p></td>
2144<td><p><code class="computeroutput">pos</code> is a valid iterator pointing to the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> or its end. </p></td>
2145</tr>
2146<tr>
2147<td><p><span class="term">Postconditions:</span></p></td>
2148<td><p>The <code class="computeroutput">item</code> will be inserted before the position <code class="computeroutput">pos</code>.<br>
2149 If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full, the last element will be overwritten. If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full and the <code class="computeroutput">pos</code> points to <code class="computeroutput">end()</code>, then the <code class="computeroutput">item</code> will not be inserted. If the capacity is <code class="computeroutput">0</code>, nothing will be inserted.<br>
2150<br>
2151 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
2152</tr>
2153<tr>
2154<td><p><span class="term">Returns:</span></p></td>
2155<td><p>Iterator to the inserted element or <code class="computeroutput">end()</code> if the <code class="computeroutput">item</code> is not inserted. (See the <span class="emphasis"><em>Effect</em></span>.) </p></td>
2156</tr>
2157<tr>
2158<td><p><span class="term">Throws:</span></p></td>
2159<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws. Whatever <code class="computeroutput">T::operator = (const T&amp;)</code> throws. </td>
2160</tr>
2161</tbody>
2162</table></div>
2163</li>
2164<li class="listitem">
2165<pre class="literallayout"><span class="identifier">iterator</span> <a name="idm46495623480192-bb"></a><span class="identifier">rinsert</span><span class="special">(</span><span class="identifier">iterator</span> pos<span class="special">,</span> <span class="identifier">rvalue_type</span> item<span class="special">)</span><span class="special">;</span></pre>Insert an element before the specified position. <p>
2166
2167
2168
2169
2170</p>
2171<p><b>Exception Safety.&#160;</b>Basic. </p>
2172<p>
2173</p>
2174<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
2175<p>
2176</p>
2177<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
2178<p>
2179</p>
2180<p><span class="bold"><strong>See Also:</strong></span></p>
2181<p><code class="computeroutput">rinsert(iterator, size_type, value_type)</code>, <code class="computeroutput">rinsert(iterator, InputIterator, InputIterator)</code>, <code class="computeroutput">insert(iterator, value_type)</code>, <code class="computeroutput">insert(iterator, size_type, value_type)</code>, <code class="computeroutput">insert(iterator, InputIterator, InputIterator)</code> </p>
2182<p>
2183</p>
2184<p>
2185</p>
2186<div class="variablelist"><table border="0" class="variablelist compact">
2187<colgroup>
2188<col align="left" valign="top">
2189<col>
2190</colgroup>
2191<tbody>
2192<tr>
2193<td><p><span class="term">Parameters:</span></p></td>
2194<td><div class="variablelist"><table border="0" class="variablelist compact">
2195<colgroup>
2196<col align="left" valign="top">
2197<col>
2198</colgroup>
2199<tbody>
2200<tr>
2201<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
2202<td><p>The element to be inserted. </p></td>
2203</tr>
2204<tr>
2205<td><p><span class="term"><code class="computeroutput">pos</code></span></p></td>
2206<td><p>An iterator specifying the position before which the <code class="computeroutput">item</code> will be inserted. </p></td>
2207</tr>
2208</tbody>
2209</table></div></td>
2210</tr>
2211<tr>
2212<td><p><span class="term">Requires:</span></p></td>
2213<td><p><code class="computeroutput">pos</code> is a valid iterator pointing to the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> or its end. </p></td>
2214</tr>
2215<tr>
2216<td><p><span class="term">Postconditions:</span></p></td>
2217<td><p>The <code class="computeroutput">item</code> will be inserted before the position <code class="computeroutput">pos</code>.<br>
2218 If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full, the last element will be overwritten. If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full and the <code class="computeroutput">pos</code> points to <code class="computeroutput">end()</code>, then the <code class="computeroutput">item</code> will not be inserted. If the capacity is <code class="computeroutput">0</code>, nothing will be inserted.<br>
2219<br>
2220 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
2221</tr>
2222<tr>
2223<td><p><span class="term">Returns:</span></p></td>
2224<td><p>Iterator to the inserted element or <code class="computeroutput">end()</code> if the <code class="computeroutput">item</code> is not inserted. (See the <span class="emphasis"><em>Effect</em></span>.) </p></td>
2225</tr>
2226<tr>
2227<td><p><span class="term">Throws:</span></p></td>
2228<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws or nothing if <code class="computeroutput">T::T(T&amp;&amp;)</code> is noexcept. </td>
2229</tr>
2230</tbody>
2231</table></div>
2232</li>
2233<li class="listitem">
2234<pre class="literallayout"><span class="identifier">iterator</span> <a name="idm46495623455200-bb"></a><span class="identifier">rinsert</span><span class="special">(</span><span class="identifier">iterator</span> pos<span class="special">)</span><span class="special">;</span></pre>Insert an element before the specified position. <p>
2235
2236
2237
2238
2239</p>
2240<p><b>Exception Safety.&#160;</b>Basic. </p>
2241<p>
2242</p>
2243<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
2244<p>
2245</p>
2246<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
2247<p>
2248</p>
2249<p><span class="bold"><strong>See Also:</strong></span></p>
2250<p><code class="computeroutput">rinsert(iterator, size_type, value_type)</code>, <code class="computeroutput">rinsert(iterator, InputIterator, InputIterator)</code>, <code class="computeroutput">insert(iterator, value_type)</code>, <code class="computeroutput">insert(iterator, size_type, value_type)</code>, <code class="computeroutput">insert(iterator, InputIterator, InputIterator)</code> </p>
2251<p>
2252</p>
2253<p>
2254</p>
2255<div class="variablelist"><table border="0" class="variablelist compact">
2256<colgroup>
2257<col align="left" valign="top">
2258<col>
2259</colgroup>
2260<tbody>
2261<tr>
2262<td><p><span class="term">Parameters:</span></p></td>
2263<td><div class="variablelist"><table border="0" class="variablelist compact">
2264<colgroup>
2265<col align="left" valign="top">
2266<col>
2267</colgroup>
2268<tbody><tr>
2269<td><p><span class="term"><code class="computeroutput">pos</code></span></p></td>
2270<td><p>An iterator specifying the position before which the <code class="computeroutput">item</code> will be inserted. </p></td>
2271</tr></tbody>
2272</table></div></td>
2273</tr>
2274<tr>
2275<td><p><span class="term">Requires:</span></p></td>
2276<td><p><code class="computeroutput">pos</code> is a valid iterator pointing to the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> or its end. </p></td>
2277</tr>
2278<tr>
2279<td><p><span class="term">Postconditions:</span></p></td>
2280<td><p>The <code class="computeroutput">item</code> will be inserted before the position <code class="computeroutput">pos</code>.<br>
2281 If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full, the last element will be overwritten. If the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> is full and the <code class="computeroutput">pos</code> points to <code class="computeroutput">end()</code>, then the <code class="computeroutput">item</code> will not be inserted. If the capacity is <code class="computeroutput">0</code>, nothing will be inserted.<br>
2282<br>
2283 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
2284</tr>
2285<tr>
2286<td><p><span class="term">Returns:</span></p></td>
2287<td><p>Iterator to the inserted element or <code class="computeroutput">end()</code> if the <code class="computeroutput">item</code> is not inserted. (See the <span class="emphasis"><em>Effect</em></span>.) </p></td>
2288</tr>
2289<tr>
2290<td><p><span class="term">Throws:</span></p></td>
2291<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T()</code> throws. Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws or nothing if <code class="computeroutput">T::T(T&amp;&amp;)</code> is noexcept. </td>
2292</tr>
2293</tbody>
2294</table></div>
2295</li>
2296<li class="listitem">
2297<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623430880-bb"></a><span class="identifier">rinsert</span><span class="special">(</span><span class="identifier">iterator</span> pos<span class="special">,</span> <span class="identifier">size_type</span> n<span class="special">,</span> <span class="identifier">param_value_type</span> item<span class="special">)</span><span class="special">;</span></pre>Insert <code class="computeroutput">n</code> copies of the <code class="computeroutput">item</code> before the specified position. <p>
2298
2299
2300
2301</p>
2302<p><b>Exception Safety.&#160;</b>Basic. </p>
2303<p>
2304</p>
2305<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
2306<p>
2307</p>
2308<p><b>Complexity.&#160;</b>Linear (in <code class="computeroutput">min[capacity().capacity(), size() + n]</code>). </p>
2309<p>
2310</p>
2311<p><b>Example.&#160;</b>Consider a <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> with the capacity of 6 and the size of 4. Its internal buffer may look like the one below.<br>
2312<br>
2313 <code class="computeroutput">|1|2|3|4| | |</code><br>
2314 <code class="computeroutput">p ___^</code><br>
2315<br>
2316After inserting 5 elements before the position <code class="computeroutput">p</code>:<br>
2317<br>
2318 <code class="computeroutput">rinsert(p, (size_t)5, 0);</code><br>
2319<br>
2320actually only 4 elements get inserted and elements <code class="computeroutput">3</code> and <code class="computeroutput">4</code> are overwritten. This is due to the fact the rinsert operation preserves the capacity. After insertion the internal buffer looks like this:<br>
2321<br>
2322<code class="computeroutput">|1|2|0|0|0|0|</code><br>
2323 <br>
2324For comparison if the capacity would not be preserved the internal buffer would then result in <code class="computeroutput">|1|2|0|0|0|0|0|3|4|</code>. </p>
2325<p>
2326</p>
2327<p><span class="bold"><strong>See Also:</strong></span></p>
2328<p><code class="computeroutput">rinsert(iterator, value_type)</code>, <code class="computeroutput">rinsert(iterator, InputIterator, InputIterator)</code>, <code class="computeroutput">insert(iterator, value_type)</code>, <code class="computeroutput">insert(iterator, size_type, value_type)</code>, <code class="computeroutput">insert(iterator, InputIterator, InputIterator)</code> </p>
2329<p>
2330</p>
2331<p>
2332</p>
2333<div class="variablelist"><table border="0" class="variablelist compact">
2334<colgroup>
2335<col align="left" valign="top">
2336<col>
2337</colgroup>
2338<tbody>
2339<tr>
2340<td><p><span class="term">Parameters:</span></p></td>
2341<td><div class="variablelist"><table border="0" class="variablelist compact">
2342<colgroup>
2343<col align="left" valign="top">
2344<col>
2345</colgroup>
2346<tbody>
2347<tr>
2348<td><p><span class="term"><code class="computeroutput">item</code></span></p></td>
2349<td><p>The element whose copies will be inserted. </p></td>
2350</tr>
2351<tr>
2352<td><p><span class="term"><code class="computeroutput">n</code></span></p></td>
2353<td><p>The number of <code class="computeroutput">item</code>s the to be inserted. </p></td>
2354</tr>
2355<tr>
2356<td><p><span class="term"><code class="computeroutput">pos</code></span></p></td>
2357<td><p>An iterator specifying the position where the <code class="computeroutput">item</code>s will be inserted. </p></td>
2358</tr>
2359</tbody>
2360</table></div></td>
2361</tr>
2362<tr>
2363<td><p><span class="term">Requires:</span></p></td>
2364<td><p><code class="computeroutput">pos</code> is a valid iterator pointing to the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> or its end. </p></td>
2365</tr>
2366<tr>
2367<td><p><span class="term">Postconditions:</span></p></td>
2368<td><p>The number of <code class="computeroutput">min[n, (end() - pos) + reserve()]</code> elements will be inserted before the position <code class="computeroutput">pos</code>.<br>
2369The number of <code class="computeroutput">min[end() - pos, max[0, n - reserve()]]</code> elements will be overwritten at the end of the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code>.<br>
2370(See <span class="emphasis"><em>Example</em></span> for the explanation.)<br>
2371<br>
2372 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
2373</tr>
2374<tr>
2375<td><p><span class="term">Throws:</span></p></td>
2376<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws. Whatever <code class="computeroutput">T::operator = (const T&amp;)</code> throws. </td>
2377</tr>
2378</tbody>
2379</table></div>
2380</li>
2381<li class="listitem">
2382<pre class="literallayout"><span class="keyword">template</span><span class="special">&lt;</span><span class="keyword">typename</span> InputIterator<span class="special">&gt;</span>
2383  <span class="keyword">void</span> <a name="idm46495623398352-bb"></a><span class="identifier">rinsert</span><span class="special">(</span><span class="identifier">iterator</span> pos<span class="special">,</span> <span class="identifier">InputIterator</span> first<span class="special">,</span> <span class="identifier">InputIterator</span> last<span class="special">)</span><span class="special">;</span></pre>Insert the range <code class="computeroutput">[first, last)</code> before the specified position. <p>
2384
2385
2386
2387</p>
2388<p><b>Exception Safety.&#160;</b>Basic. </p>
2389<p>
2390</p>
2391<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
2392<p>
2393</p>
2394<p><b>Complexity.&#160;</b>Linear (in <code class="computeroutput">[size() + std::distance(first, last)]</code>; in <code class="computeroutput">min[capacity().capacity(), size() + std::distance(first, last)]</code> if the <code class="computeroutput">InputIterator</code> is a <a href="https://www.boost.org/sgi/stl/RandomAccessIterator.html" target="_top">RandomAccessIterator</a>). </p>
2395<p>
2396</p>
2397<p><b>Example.&#160;</b>Consider a <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> with the capacity of 6 and the size of 4. Its internal buffer may look like the one below.<br>
2398<br>
2399 <code class="computeroutput">|1|2|3|4| | |</code><br>
2400 <code class="computeroutput">p ___^</code><br>
2401<br>
2402After inserting a range of elements before the position <code class="computeroutput">p</code>:<br>
2403<br>
2404 <code class="computeroutput">int array[] = { 5, 6, 7, 8, 9 };</code><br>
2405<code class="computeroutput">insert(p, array, array + 5);</code><br>
2406<br>
2407 actually only elements <code class="computeroutput">5</code>, <code class="computeroutput">6</code>, <code class="computeroutput">7</code> and <code class="computeroutput">8</code> from the specified range get inserted and elements <code class="computeroutput">3</code> and <code class="computeroutput">4</code> are overwritten. This is due to the fact the rinsert operation preserves the capacity. After insertion the internal buffer looks like this:<br>
2408<br>
2409<code class="computeroutput">|1|2|5|6|7|8|</code><br>
2410<br>
2411For comparison if the capacity would not be preserved the internal buffer would then result in <code class="computeroutput">|1|2|5|6|7|8|9|3|4|</code>. </p>
2412<p>
2413</p>
2414<p><span class="bold"><strong>See Also:</strong></span></p>
2415<p><code class="computeroutput">rinsert(iterator, value_type)</code>, <code class="computeroutput">rinsert(iterator, size_type, value_type)</code>, <code class="computeroutput">insert(iterator, value_type)</code>, <code class="computeroutput">insert(iterator, size_type, value_type)</code>, <code class="computeroutput">insert(iterator, InputIterator, InputIterator)</code> </p>
2416<p>
2417</p>
2418<p>
2419</p>
2420<div class="variablelist"><table border="0" class="variablelist compact">
2421<colgroup>
2422<col align="left" valign="top">
2423<col>
2424</colgroup>
2425<tbody>
2426<tr>
2427<td><p><span class="term">Parameters:</span></p></td>
2428<td><div class="variablelist"><table border="0" class="variablelist compact">
2429<colgroup>
2430<col align="left" valign="top">
2431<col>
2432</colgroup>
2433<tbody>
2434<tr>
2435<td><p><span class="term"><code class="computeroutput">first</code></span></p></td>
2436<td><p>The beginning of the range to be inserted. </p></td>
2437</tr>
2438<tr>
2439<td><p><span class="term"><code class="computeroutput">last</code></span></p></td>
2440<td><p>The end of the range to be inserted. </p></td>
2441</tr>
2442<tr>
2443<td><p><span class="term"><code class="computeroutput">pos</code></span></p></td>
2444<td><p>An iterator specifying the position where the range will be inserted. </p></td>
2445</tr>
2446</tbody>
2447</table></div></td>
2448</tr>
2449<tr>
2450<td><p><span class="term">Requires:</span></p></td>
2451<td><p><code class="computeroutput">pos</code> is a valid iterator pointing to the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> or its end.<br>
2452 Valid range <code class="computeroutput">[first, last)</code> where <code class="computeroutput">first</code> and <code class="computeroutput">last</code> meet the requirements of an <a href="https://www.boost.org/sgi/stl/InputIterator.html" target="_top">InputIterator</a>. </p></td>
2453</tr>
2454<tr>
2455<td><p><span class="term">Postconditions:</span></p></td>
2456<td><p>Elements from the range <code class="computeroutput">[first, last - max[0, distance(first, last) - (end() - pos) - reserve()])</code> will be inserted before the position <code class="computeroutput">pos</code>.<br>
2457The number of <code class="computeroutput">min[end() - pos, max[0, distance(first, last) - reserve()]]</code> elements will be overwritten at the end of the <code class="computeroutput"><a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a></code>.<br>
2458(See <span class="emphasis"><em>Example</em></span> for the explanation.)<br>
2459<br>
2460 The amount of allocated memory in the internal buffer may be predictively increased. </p></td>
2461</tr>
2462<tr>
2463<td><p><span class="term">Throws:</span></p></td>
2464<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::T(const T&amp;)</code> throws. Whatever <code class="computeroutput">T::operator = (const T&amp;)</code> throws. </td>
2465</tr>
2466</tbody>
2467</table></div>
2468</li>
2469<li class="listitem">
2470<pre class="literallayout"><span class="identifier">iterator</span> <a name="idm46495623359728-bb"></a><span class="identifier">erase</span><span class="special">(</span><span class="identifier">iterator</span> pos<span class="special">)</span><span class="special">;</span></pre>Remove an element at the specified position. <p>
2471
2472
2473
2474
2475</p>
2476<p><b>Exception Safety.&#160;</b>Basic. </p>
2477<p>
2478</p>
2479<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
2480<p>
2481</p>
2482<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
2483<p>
2484</p>
2485<p><span class="bold"><strong>See Also:</strong></span></p>
2486<p><code class="computeroutput">erase(iterator, iterator)</code>, <code class="computeroutput">rerase(iterator)</code>, <code class="computeroutput">rerase(iterator, iterator)</code>, <code class="computeroutput">clear()</code> </p>
2487<p>
2488</p>
2489<p>
2490</p>
2491<div class="variablelist"><table border="0" class="variablelist compact">
2492<colgroup>
2493<col align="left" valign="top">
2494<col>
2495</colgroup>
2496<tbody>
2497<tr>
2498<td><p><span class="term">Parameters:</span></p></td>
2499<td><div class="variablelist"><table border="0" class="variablelist compact">
2500<colgroup>
2501<col align="left" valign="top">
2502<col>
2503</colgroup>
2504<tbody><tr>
2505<td><p><span class="term"><code class="computeroutput">pos</code></span></p></td>
2506<td><p>An iterator pointing at the element to be removed. </p></td>
2507</tr></tbody>
2508</table></div></td>
2509</tr>
2510<tr>
2511<td><p><span class="term">Requires:</span></p></td>
2512<td><p><code class="computeroutput">pos</code> is a valid iterator pointing to the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> (but not an <code class="computeroutput">end()</code>). </p></td>
2513</tr>
2514<tr>
2515<td><p><span class="term">Postconditions:</span></p></td>
2516<td><p>The element at the position <code class="computeroutput">pos</code> is removed.<br>
2517<br>
2518 The amount of allocated memory in the internal buffer may be predictively decreased. </p></td>
2519</tr>
2520<tr>
2521<td><p><span class="term">Returns:</span></p></td>
2522<td><p>Iterator to the first element remaining beyond the removed element or <code class="computeroutput">end()</code> if no such element exists. </p></td>
2523</tr>
2524<tr>
2525<td><p><span class="term">Throws:</span></p></td>
2526<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::operator = (const T&amp;)</code> throws or nothing if <code class="computeroutput">T::operator = (T&amp;&amp;)</code> is noexcept. </td>
2527</tr>
2528</tbody>
2529</table></div>
2530</li>
2531<li class="listitem">
2532<pre class="literallayout"><span class="identifier">iterator</span> <a name="idm46495623341616-bb"></a><span class="identifier">erase</span><span class="special">(</span><span class="identifier">iterator</span> first<span class="special">,</span> <span class="identifier">iterator</span> last<span class="special">)</span><span class="special">;</span></pre>Erase the range <code class="computeroutput">[first, last)</code>. <p>
2533
2534
2535
2536
2537</p>
2538<p><b>Exception Safety.&#160;</b>Basic. </p>
2539<p>
2540</p>
2541<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
2542<p>
2543</p>
2544<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
2545<p>
2546</p>
2547<p><span class="bold"><strong>See Also:</strong></span></p>
2548<p><code class="computeroutput">erase(iterator)</code>, <code class="computeroutput">rerase(iterator)</code>, <code class="computeroutput">rerase(iterator, iterator)</code>, <code class="computeroutput">clear()</code> </p>
2549<p>
2550</p>
2551<p>
2552</p>
2553<div class="variablelist"><table border="0" class="variablelist compact">
2554<colgroup>
2555<col align="left" valign="top">
2556<col>
2557</colgroup>
2558<tbody>
2559<tr>
2560<td><p><span class="term">Parameters:</span></p></td>
2561<td><div class="variablelist"><table border="0" class="variablelist compact">
2562<colgroup>
2563<col align="left" valign="top">
2564<col>
2565</colgroup>
2566<tbody>
2567<tr>
2568<td><p><span class="term"><code class="computeroutput">first</code></span></p></td>
2569<td><p>The beginning of the range to be removed. </p></td>
2570</tr>
2571<tr>
2572<td><p><span class="term"><code class="computeroutput">last</code></span></p></td>
2573<td><p>The end of the range to be removed. </p></td>
2574</tr>
2575</tbody>
2576</table></div></td>
2577</tr>
2578<tr>
2579<td><p><span class="term">Requires:</span></p></td>
2580<td><p>Valid range <code class="computeroutput">[first, last)</code>. </p></td>
2581</tr>
2582<tr>
2583<td><p><span class="term">Postconditions:</span></p></td>
2584<td><p>The elements from the range <code class="computeroutput">[first, last)</code> are removed. (If <code class="computeroutput">first == last</code> nothing is removed.)<br>
2585<br>
2586 The amount of allocated memory in the internal buffer may be predictively decreased. </p></td>
2587</tr>
2588<tr>
2589<td><p><span class="term">Returns:</span></p></td>
2590<td><p>Iterator to the first element remaining beyond the removed elements or <code class="computeroutput">end()</code> if no such element exists. </p></td>
2591</tr>
2592<tr>
2593<td><p><span class="term">Throws:</span></p></td>
2594<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::operator = (const T&amp;)</code> throws or nothing if <code class="computeroutput">T::operator = (T&amp;&amp;)</code> is noexcept. </td>
2595</tr>
2596</tbody>
2597</table></div>
2598</li>
2599<li class="listitem">
2600<pre class="literallayout"><span class="identifier">iterator</span> <a name="idm46495623322720-bb"></a><span class="identifier">rerase</span><span class="special">(</span><span class="identifier">iterator</span> pos<span class="special">)</span><span class="special">;</span></pre>Remove an element at the specified position. <p>
2601
2602
2603
2604
2605</p>
2606<p><b>Exception Safety.&#160;</b>Basic. </p>
2607<p>
2608</p>
2609<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
2610<p>
2611</p>
2612<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
2613<p>
2614</p>
2615<div class="note"><table border="0" summary="Note">
2616<tr>
2617<td rowspan="2" align="center" valign="top" width="25"><img alt="[Note]" src="../../../doc/src/images/note.png"></td>
2618<th align="left">Note</th>
2619</tr>
2620<tr><td align="left" valign="top"><p>Basically there is no difference between <code class="computeroutput">erase(iterator)</code> and this method. It is implemented only for consistency with the base <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a></code></code>. </p></td></tr>
2621</table></div>
2622<p>
2623</p>
2624<p><span class="bold"><strong>See Also:</strong></span></p>
2625<p><code class="computeroutput">erase(iterator)</code>, <code class="computeroutput">erase(iterator, iterator)</code>, <code class="computeroutput">rerase(iterator, iterator)</code>, <code class="computeroutput">clear()</code> </p>
2626<p>
2627</p>
2628<p>
2629</p>
2630<div class="variablelist"><table border="0" class="variablelist compact">
2631<colgroup>
2632<col align="left" valign="top">
2633<col>
2634</colgroup>
2635<tbody>
2636<tr>
2637<td><p><span class="term">Parameters:</span></p></td>
2638<td><div class="variablelist"><table border="0" class="variablelist compact">
2639<colgroup>
2640<col align="left" valign="top">
2641<col>
2642</colgroup>
2643<tbody><tr>
2644<td><p><span class="term"><code class="computeroutput">pos</code></span></p></td>
2645<td><p>An iterator pointing at the element to be removed. </p></td>
2646</tr></tbody>
2647</table></div></td>
2648</tr>
2649<tr>
2650<td><p><span class="term">Requires:</span></p></td>
2651<td><p><code class="computeroutput">pos</code> is a valid iterator pointing to the <code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code> (but not an <code class="computeroutput">end()</code>).<br>
2652<br>
2653 The amount of allocated memory in the internal buffer may be predictively decreased. </p></td>
2654</tr>
2655<tr>
2656<td><p><span class="term">Postconditions:</span></p></td>
2657<td><p>The element at the position <code class="computeroutput">pos</code> is removed. </p></td>
2658</tr>
2659<tr>
2660<td><p><span class="term">Returns:</span></p></td>
2661<td><p>Iterator to the first element remaining in front of the removed element or <code class="computeroutput">begin()</code> if no such element exists. </p></td>
2662</tr>
2663<tr>
2664<td><p><span class="term">Throws:</span></p></td>
2665<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::operator = (const T&amp;)</code> throws or nothing if <code class="computeroutput">T::operator = (T&amp;&amp;)</code> is noexcept. </td>
2666</tr>
2667</tbody>
2668</table></div>
2669</li>
2670<li class="listitem">
2671<pre class="literallayout"><span class="identifier">iterator</span> <a name="idm46495623302480-bb"></a><span class="identifier">rerase</span><span class="special">(</span><span class="identifier">iterator</span> first<span class="special">,</span> <span class="identifier">iterator</span> last<span class="special">)</span><span class="special">;</span></pre>Erase the range <code class="computeroutput">[first, last)</code>. <p>
2672
2673
2674
2675
2676</p>
2677<p><b>Exception Safety.&#160;</b>Basic. </p>
2678<p>
2679</p>
2680<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
2681<p>
2682</p>
2683<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
2684<p>
2685</p>
2686<div class="note"><table border="0" summary="Note">
2687<tr>
2688<td rowspan="2" align="center" valign="top" width="25"><img alt="[Note]" src="../../../doc/src/images/note.png"></td>
2689<th align="left">Note</th>
2690</tr>
2691<tr><td align="left" valign="top"><p>Basically there is no difference between <code class="computeroutput">erase(iterator, iterator)</code> and this method. It is implemented only for consistency with the base <code class="computeroutput">&lt;<code class="computeroutput"><a class="link" href="circular_buffer.html" title="Class template circular_buffer">circular_buffer</a></code></code>. </p></td></tr>
2692</table></div>
2693<p>
2694</p>
2695<p><span class="bold"><strong>See Also:</strong></span></p>
2696<p><code class="computeroutput">erase(iterator)</code>, <code class="computeroutput">erase(iterator, iterator)</code>, <code class="computeroutput">rerase(iterator)</code>, <code class="computeroutput">clear()</code> </p>
2697<p>
2698</p>
2699<p>
2700</p>
2701<div class="variablelist"><table border="0" class="variablelist compact">
2702<colgroup>
2703<col align="left" valign="top">
2704<col>
2705</colgroup>
2706<tbody>
2707<tr>
2708<td><p><span class="term">Parameters:</span></p></td>
2709<td><div class="variablelist"><table border="0" class="variablelist compact">
2710<colgroup>
2711<col align="left" valign="top">
2712<col>
2713</colgroup>
2714<tbody>
2715<tr>
2716<td><p><span class="term"><code class="computeroutput">first</code></span></p></td>
2717<td><p>The beginning of the range to be removed. </p></td>
2718</tr>
2719<tr>
2720<td><p><span class="term"><code class="computeroutput">last</code></span></p></td>
2721<td><p>The end of the range to be removed. </p></td>
2722</tr>
2723</tbody>
2724</table></div></td>
2725</tr>
2726<tr>
2727<td><p><span class="term">Requires:</span></p></td>
2728<td><p>Valid range <code class="computeroutput">[first, last)</code>. </p></td>
2729</tr>
2730<tr>
2731<td><p><span class="term">Postconditions:</span></p></td>
2732<td><p>The elements from the range <code class="computeroutput">[first, last)</code> are removed. (If <code class="computeroutput">first == last</code> nothing is removed.)<br>
2733<br>
2734 The amount of allocated memory in the internal buffer may be predictively decreased. </p></td>
2735</tr>
2736<tr>
2737<td><p><span class="term">Returns:</span></p></td>
2738<td><p>Iterator to the first element remaining in front of the removed elements or <code class="computeroutput">begin()</code> if no such element exists. </p></td>
2739</tr>
2740<tr>
2741<td><p><span class="term">Throws:</span></p></td>
2742<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). Whatever <code class="computeroutput">T::operator = (const T&amp;)</code> throws or nothing if <code class="computeroutput">T::operator = (T&amp;&amp;)</code> is noexcept. </td>
2743</tr>
2744</tbody>
2745</table></div>
2746</li>
2747<li class="listitem">
2748<pre class="literallayout"><span class="keyword">void</span> <a name="idm46495623281280-bb"></a><span class="identifier">clear</span><span class="special">(</span><span class="special">)</span><span class="special">;</span></pre>Remove all stored elements from the space optimized circular buffer. <p>
2749
2750</p>
2751<p><b>Exception Safety.&#160;</b>Basic. </p>
2752<p>
2753</p>
2754<p><b>Iterator Invalidation.&#160;</b>Invalidates all iterators pointing to the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code> (except iterators equal to <code class="computeroutput">end()</code>). </p>
2755<p>
2756</p>
2757<p><b>Complexity.&#160;</b>Linear (in the size of the <code class="computeroutput"><code class="computeroutput"><a class="link" href="circular_idm46495624036048.html" title="Class template circular_buffer_space_optimized">circular_buffer_space_optimized</a></code></code>). </p>
2758<p>
2759</p>
2760<p><span class="bold"><strong>See Also:</strong></span></p>
2761<p><code class="computeroutput">~circular_buffer_space_optimized()</code>, <code class="computeroutput">erase(iterator)</code>, <code class="computeroutput">erase(iterator, iterator)</code>, <code class="computeroutput">rerase(iterator)</code>, <code class="computeroutput">rerase(iterator, iterator)</code> </p>
2762<p>
2763</p>
2764<p>
2765</p>
2766<div class="variablelist"><table border="0" class="variablelist compact">
2767<colgroup>
2768<col align="left" valign="top">
2769<col>
2770</colgroup>
2771<tbody>
2772<tr>
2773<td><p><span class="term">Postconditions:</span></p></td>
2774<td><p><code class="computeroutput">size() == 0</code><br>
2775<br>
2776 The amount of allocated memory in the internal buffer may be predictively decreased. </p></td>
2777</tr>
2778<tr>
2779<td><p><span class="term">Throws:</span></p></td>
2780<td>An allocation error if memory is exhausted (<code class="computeroutput">std::bad_alloc</code> if the standard allocator is used). </td>
2781</tr>
2782</tbody>
2783</table></div>
2784</li>
2785</ol></div>
2786</div>
2787</div>
2788</div>
2789<table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr>
2790<td align="left"></td>
2791<td align="right"><div class="copyright-footer">Copyright &#169; 2003-2013 Jan Gaspar<p>
2792        Distributed under the Boost Software License, Version 1.0. (See accompanying
2793        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>)
2794      </p>
2795</div></td>
2796</tr></table>
2797<hr>
2798<div class="spirit-nav">
2799<a accesskey="p" href="swap_idm46495624055088.html"><img src="../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../boost_circular_buffer_c___reference.html#header.boost.circular_buffer.space_optimized_hpp"><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="../circular_buffer/s14.html"><img src="../../../doc/src/images/next.png" alt="Next"></a>
2800</div>
2801</body>
2802</html>
2803