circular_buffer_space_optimized<T, Alloc> |
|
The
circular_buffer_space_optimized
container is an adaptor of the
circular_buffer
. The
functionality of the
circular_buffer_space_optimized
is similar to
the base
circular_buffer
except it does not allocate memory at
once when created rather it allocates memory as needed. (The predictive memory
allocation is similar to typical
std::vector
implementation.)
Moreover the memory is automatically freed as the size of the container
decreases.
|
|
| Figure: |
The memory allocation process of the space optimized circular
buffer. The
min_capacity
represents the minimal guaranteed amount
of allocated memory. The allocated memory will never drop under this value. By
default the
min_capacity
is set to 0.
|
The auto-resizing mode of the space optimized circular buffer can be useful in
situations when the container can possibly store large number of elements but
most of its lifetime the container stores just few of them. The usage of the
circular_buffer_space_optimized
will result in decreased memory consumption and can improve the CPU cache
effectiveness.
namespace boost {
template <class T, class Alloc>
class circular_buffer_space_optimized
{
public:
typedef Alloc allocator_type;
typedef implementation-defined array_range;
typedef implementation-defined capacity_control;
typedef implementation-defined const_array_range;
typedef implementation-defined const_iterator;
typedef typename Alloc::const_pointer const_pointer;
typedef typename Alloc::const_reference const_reference;
typedef implementation-defined const_reverse_iterator;
typedef typename Alloc::difference_type difference_type;
typedef implementation-defined iterator;
typedef typename Alloc::pointer pointer;
typedef typename Alloc::reference reference;
typedef implementation-defined reverse_iterator;
typedef typename Alloc::size_type size_type;
typedef typename Alloc::value_type value_type;
template <class InputIterator>
circular_buffer_space_optimized(capacity_control capacity_ctrl,
InputIterator first, InputIterator last,
const allocator_type& alloc = allocator_type());
template <class InputIterator>
circular_buffer_space_optimized(InputIterator first,
InputIterator last, const allocator_type& alloc = allocator_type());
template <class InputIterator>
circular_buffer_space_optimized(capacity_control capacity_ctrl, InputIterator first, InputIterator last);
template <class InputIterator>
circular_buffer_space_optimized(InputIterator first, InputIterator last);
circular_buffer_space_optimized(capacity_control capacity_ctrl,
size_type n, value_type item,
const allocator_type& alloc = allocator_type());
circular_buffer_space_optimized(capacity_control capacity_ctrl,
value_type item, const allocator_type& alloc = allocator_type());
explicit circular_buffer_space_optimized(capacity_control capacity_ctrl, const allocator_type& alloc = allocator_type());
explicit circular_buffer_space_optimized(const allocator_type& alloc = allocator_type());
const_array_range array_one() const;
array_range array_one();
const_array_range array_two() const;
array_range array_two();
template <class InputIterator>
void assign(capacity_control capacity_ctrl, InputIterator first, InputIterator last);
void assign(capacity_control capacity_ctrl, size_type n, value_type item);
template <class InputIterator>
void assign(size_type capacity, InputIterator first, InputIterator last);
template <class InputIterator>
void assign(InputIterator first, InputIterator last);
void assign(size_type capacity, size_type n, value_type item);
void assign(size_type n, value_type item);
value_type at(size_type index) const;
reference at(size_type index);
value_type back() const;
reference back();
const_iterator begin() const;
iterator begin();
size_type capacity() const;
void clear();
bool empty() const;
const_iterator end() const;
iterator end();
iterator erase(iterator first, iterator last);
iterator erase(iterator pos);
value_type front() const;
reference front();
bool full() const;
allocator_type& get_allocator();
allocator_type get_allocator() const;
template <class InputIterator>
void insert(iterator pos, InputIterator first, InputIterator last);
void insert(iterator pos, size_type n, value_type item);
iterator insert(iterator pos, value_type item = value_type());
pointer linearize();
size_type max_size() const;
size_type min_capacity() const;
circular_buffer_space_optimized<T,Alloc>& operator=(const circular_buffer_space_optimized<T,Alloc>& cb);
value_type operator[](size_type index) const;
reference operator[](size_type index);
void pop_back();
void pop_front();
void push_back(value_type item = value_type());
void push_front(value_type item = value_type());
const_reverse_iterator rbegin() const;
reverse_iterator rbegin();
const_reverse_iterator rend() const;
reverse_iterator rend();
iterator rerase(iterator first, iterator last);
iterator rerase(iterator pos);
void resize(size_type new_size, value_type item = value_type());
template <class InputIterator>
void rinsert(iterator pos, InputIterator first, InputIterator last);
void rinsert(iterator pos, size_type n, value_type item);
iterator rinsert(iterator pos, value_type item = value_type());
void rresize(size_type new_size, value_type item = value_type());
void rset_capacity(size_type new_capacity);
void set_capacity(size_type new_capacity);
void set_min_capacity(size_type new_min_capacity);
size_type size() const;
void swap(circular_buffer_space_optimized<T,Alloc>& cb);
};
template <class T, class Alloc>
bool operator!=(const circular_buffer_space_optimized<T,Alloc>& lhs,
const circular_buffer_space_optimized<T,Alloc>& rhs);
template <class T, class Alloc>
bool operator<(const circular_buffer_space_optimized<T,Alloc>& lhs,
const circular_buffer_space_optimized<T,Alloc>& rhs);
template <class T, class Alloc>
bool operator<=(const circular_buffer_space_optimized<T,Alloc>& lhs,
const circular_buffer_space_optimized<T,Alloc>& rhs);
template <class T, class Alloc>
bool operator==(const circular_buffer_space_optimized<T,Alloc>& lhs,
const circular_buffer_space_optimized<T,Alloc>& rhs);
template <class T, class Alloc>
bool operator>(const circular_buffer_space_optimized<T,Alloc>& lhs,
const circular_buffer_space_optimized<T,Alloc>& rhs);
template <class T, class Alloc>
bool operator>=(const circular_buffer_space_optimized<T,Alloc>& lhs,
const circular_buffer_space_optimized<T,Alloc>& rhs);
template <class T, class Alloc>
void swap(circular_buffer_space_optimized<T,Alloc>& lhs,
circular_buffer_space_optimized<T,Alloc>& rhs);
} // namespace boost
|
The
circular_buffer_space_optimized
is defined in the file
boost/circular_buffer.hpp
.
There is also a forward declaration for the
circular_buffer_space_optimized
in the header file
boost/circular_buffer_fwd.hpp
.
Random AccessContainer, Front Insertion Sequence, Back Insertion Sequence, Assignable (SGI specific), Equality Comparable, LessThan Comparable (SGI specific)
Template parameters, members and friend functions of the
circular_buffer_space_optimized
are almost the same as for the base
circular_buffer
. Refer the
circular_buffer
documentation
and also its
source code documentation
for a detailed description.
The specific methods of the
circular_buffer_space_optimized
are
listed below.
template <class InputIterator>
|
|||||||||
template <class InputIterator>
|
|||||||||
template <class InputIterator>
|
|||||||||
template <class InputIterator>
|
|||||||||
circular_buffer_space_optimized(capacity_control capacity_ctrl,
|
|||||||||
circular_buffer_space_optimized(capacity_control capacity_ctrl,
|
|||||||||
explicit circular_buffer_space_optimized(capacity_control capacity_ctrl, const allocator_type& alloc = allocator_type());
|
|||||||||
explicit circular_buffer_space_optimized(const allocator_type& alloc = allocator_type());
|
template <class InputIterator>
|
|||||||||
void assign(capacity_control capacity_ctrl, size_type n, value_type item);
|
|||||||||
iterator erase(iterator first, iterator last);
|
|||||||||
iterator erase(iterator pos);
|
|||||||||
template <class InputIterator>
|
|||||||||
void insert(iterator pos, size_type n, value_type item);
|
|||||||||
iterator insert(iterator pos, value_type item = value_type());
|
|||||||||
size_type min_capacity() const;
|
|||||||||
void pop_back();
|
|||||||||
void pop_front();
|
|||||||||
void push_back(value_type item = value_type());
|
|||||||||
void push_front(value_type item = value_type());
|
|||||||||
iterator rerase(iterator first, iterator last);
|
|||||||||
iterator rerase(iterator pos);
|
|||||||||
template <class InputIterator>
|
|||||||||
void rinsert(iterator pos, size_type n, value_type item);
|
|||||||||
iterator rinsert(iterator pos, value_type item = value_type());
|
|||||||||
void rset_capacity(size_type new_capacity);
|
|||||||||
void set_capacity(size_type new_capacity);
|
|||||||||
void set_min_capacity(size_type new_min_capacity);
|
|||||||||
void swap(circular_buffer_space_optimized<T,Alloc>& cb);
|
TODO remove this section
The behaviour of memory auto-resizing is as follows:
circular_buffer_space_optimized
is created.
circular_buffer_space_optimized
container is created the allocated memory reflects the size of the container.
push_back
,
push_front
,
insert
and
rinsert
will predictively increase the allocated memory if necessary. (The predictive
memory allocation is similar to
std::vector
.)
set_capacity
,
resize
,
assign
,
insert
(range or n items),
rinsert
(range or n items),
erase
(range) and
clear
will accommodate the allocated memory as necessary.
pop_back
,
pop_front
,
erase
and
clear
will predictively decrease the allocated memory.
The semantics of the
circular_buffer_space_optimized
then follows
the
semantics
of the base
circular_buffer
except the invalidation rules.
The rule for iterator invalidation for
circular_buffer_space_optimized
is as follows:
data
,
set_capacity
,
resize
,
operator=
,
assign
,
swap
,
push_back
,
push_front
,
pop_back
,
pop_front
,
insert
,
rinsert
,
erase
and
clear
invalidate all iterators pointing to
the
circular_buffer_space_optimized
.
boost::circular_buffer,
std::vector
The idea of the space optimized circular buffer has been introduced by Pavel Vozenilek.
| Copyright © 2003-2005 Jan Gaspar |
|