BDE 4.14.0 Production release
|
#include <bslstl_deque.h>
Public Types | |
typedef VALUE_TYPE & | reference |
typedef const VALUE_TYPE & | const_reference |
typedef Iterator | iterator |
typedef ConstIterator | const_iterator |
typedef std::size_t | size_type |
typedef std::ptrdiff_t | difference_type |
typedef VALUE_TYPE | value_type |
typedef ALLOCATOR | allocator_type |
typedef AllocatorTraits::pointer | pointer |
typedef AllocatorTraits::const_pointer | const_pointer |
typedef bsl::reverse_iterator< Iterator > | reverse_iterator |
typedef bsl::reverse_iterator< ConstIterator > | const_reverse_iterator |
Public Types inherited from bsl::Deque_Base< VALUE_TYPE > | |
typedef VALUE_TYPE & | reference |
typedef const VALUE_TYPE & | const_reference |
typedef Iterator | iterator |
typedef ConstIterator | const_iterator |
typedef std::size_t | size_type |
typedef std::ptrdiff_t | difference_type |
typedef VALUE_TYPE | value_type |
typedef bsl::reverse_iterator< Iterator > | reverse_iterator |
typedef bsl::reverse_iterator< ConstIterator > | const_reverse_iterator |
Public Member Functions | |
deque () | |
deque (const ALLOCATOR &basicAllocator) | |
deque (size_type numElements, const ALLOCATOR &basicAllocator=ALLOCATOR()) | |
deque (size_type numElements, const VALUE_TYPE &value, const ALLOCATOR &basicAllocator=ALLOCATOR()) | |
template<class INPUT_ITERATOR > | |
deque (INPUT_ITERATOR first, INPUT_ITERATOR last, const ALLOCATOR &basicAllocator=ALLOCATOR()) | |
deque (const deque &original) | |
deque (const deque &original, const typename type_identity< ALLOCATOR >::type &basicAllocator) | |
deque (BloombergLP::bslmf::MovableRef< deque > original) | |
deque (BloombergLP::bslmf::MovableRef< deque > original, const typename type_identity< ALLOCATOR >::type &basicAllocator) | |
~deque () | |
Destroy this object. | |
deque & | operator= (const deque &rhs) |
template<class INPUT_ITERATOR > | |
deque &operator=(BloombergLP::bslmf::MovableRef< deque > rhs) BSLS_KEYWORD_NOEXCEPT_SPECIFICATION(AllocatorTraits void | assign (INPUT_ITERATOR first, INPUT_ITERATOR last) |
void | assign (size_type numElements, const VALUE_TYPE &value) |
void | reserve (size_type numElements) |
void | resize (size_type newSize) |
void | resize (size_type newSize, const VALUE_TYPE &value) |
void | shrink_to_fit () |
void | push_front (const VALUE_TYPE &value) |
void | push_front (BloombergLP::bslmf::MovableRef< value_type > value) |
void | push_back (const VALUE_TYPE &value) |
void | push_back (BloombergLP::bslmf::MovableRef< value_type > value) |
template<class... Args> | |
reference | emplace_front (Args &&... arguments) |
template<class... Args> | |
reference | emplace_back (Args &&... arguments) |
template<class... Args> | |
iterator | emplace (const_iterator position, Args &&... arguments) |
void | pop_front () |
void | pop_back () |
iterator | insert (const_iterator position, const VALUE_TYPE &value) |
iterator | insert (const_iterator position, BloombergLP::bslmf::MovableRef< value_type > value) |
iterator | insert (const_iterator position, size_type numElements, const VALUE_TYPE &value) |
template<class INPUT_ITERATOR > | |
iterator | insert (const_iterator position, INPUT_ITERATOR first, INPUT_ITERATOR last) |
iterator | erase (const_iterator position) |
iterator | erase (const_iterator first, const_iterator last) |
allocator_type | get_allocator () const BSLS_KEYWORD_NOEXCEPT |
Return the allocator used by this deque to supply memory. | |
size_type | max_size () const BSLS_KEYWORD_NOEXCEPT |
template<class INPUT_ITERATOR > | |
deque< VALUE_TYPE, ALLOCATOR >::size_type | privateAppend (INPUT_ITERATOR first, INPUT_ITERATOR last, std::random_access_iterator_tag) |
template<class INPUT_ITERATOR > | |
deque< VALUE_TYPE, ALLOCATOR >::size_type | privateAppend (INPUT_ITERATOR first, INPUT_ITERATOR last, std::input_iterator_tag) |
template<class INTEGRAL_TYPE > | |
void | privateInsertDispatch (const_iterator position, INTEGRAL_TYPE numElements, INTEGRAL_TYPE value, BloombergLP::bslmf::MatchArithmeticType, BloombergLP::bslmf::Nil) |
template<class INPUT_ITERATOR > | |
deque< VALUE_TYPE, ALLOCATOR >::size_type | privatePrepend (INPUT_ITERATOR first, INPUT_ITERATOR last, std::input_iterator_tag tag) |
template<class INPUT_ITERATOR > | |
deque< VALUE_TYPE, ALLOCATOR >::size_type | privatePrepend (INPUT_ITERATOR first, INPUT_ITERATOR last, std::bidirectional_iterator_tag) |
template<class INPUT_ITERATOR > | |
deque< VALUE_TYPE, ALLOCATOR >::size_type | privatePrepend (INPUT_ITERATOR first, INPUT_ITERATOR last, std::random_access_iterator_tag) |
template<class INPUT_ITERATOR > | |
void | assign (INPUT_ITERATOR first, INPUT_ITERATOR last) |
template<class... Args> | |
deque< VALUE_TYPE, ALLOCATOR >::reference | emplace_front (Args &&...arguments) |
template<class... Args> | |
deque< VALUE_TYPE, ALLOCATOR >::reference | emplace_back (Args &&...arguments) |
template<class... Args> | |
deque< VALUE_TYPE, ALLOCATOR >::iterator | emplace (const_iterator position, Args &&... arguments) |
template<class INPUT_ITERATOR > | |
deque< VALUE_TYPE, ALLOCATOR >::iterator | insert (const_iterator position, INPUT_ITERATOR first, INPUT_ITERATOR last) |
Public Member Functions inherited from bsl::Deque_Base< VALUE_TYPE > | |
iterator | begin () BSLS_KEYWORD_NOEXCEPT |
iterator | end () BSLS_KEYWORD_NOEXCEPT |
reverse_iterator | rbegin () BSLS_KEYWORD_NOEXCEPT |
reverse_iterator | rend () BSLS_KEYWORD_NOEXCEPT |
reference | operator[] (size_type position) |
reference | at (size_type position) |
reference | front () |
reference | back () |
const_iterator | begin () const BSLS_KEYWORD_NOEXCEPT |
const_iterator | cbegin () const BSLS_KEYWORD_NOEXCEPT |
const_iterator | end () const BSLS_KEYWORD_NOEXCEPT |
const_iterator | cend () const BSLS_KEYWORD_NOEXCEPT |
const_reverse_iterator | rbegin () const BSLS_KEYWORD_NOEXCEPT |
const_reverse_iterator | crbegin () const BSLS_KEYWORD_NOEXCEPT |
const_reverse_iterator | rend () const BSLS_KEYWORD_NOEXCEPT |
const_reverse_iterator | crend () const BSLS_KEYWORD_NOEXCEPT |
size_type | size () const BSLS_KEYWORD_NOEXCEPT |
Return the number of elements contained by this deque. | |
size_type | capacity () const BSLS_KEYWORD_NOEXCEPT |
bool | empty () const BSLS_KEYWORD_NOEXCEPT |
const_reference | operator[] (size_type position) const |
const_reference | at (size_type position) const |
const_reference | front () const |
const_reference | back () const |
Public Attributes | |
void swap(deque< VALUE_TYPE, ALLOCATOR > &other) BSLS_KEYWORD_NOEXCEPT_SPECIFICATION(AllocatorTraits void | clear () BSLS_KEYWORD_NOEXCEPT |
Friends | |
template<class VALUE_TYPE2 , class ALLOCATOR2 > | |
class | Deque_BlockCreator |
template<class VALUE_TYPE2 , class ALLOCATOR2 > | |
class | Deque_BlockProctor |
template<class VALUE_TYPE2 , class ALLOCATOR2 > | |
class | Deque_Guard |
Additional Inherited Members | |
Protected Attributes inherited from bsl::Deque_Base< VALUE_TYPE > | |
BlockPtr * | d_blocks_p |
std::size_t | d_blocksLength |
IteratorImp | d_start |
IteratorImp | d_finish |
This class template provides an STL-compliant deque
that conforms to the bslma::Allocator
model. For the requirements of a deque class, consult the C++11 standard. In particular, this implementation offers the general rules that:
bslstl::StdExceptUtil::throwLengthError
.at
method that attempts to access a position outside of the valid range of a deque triggers a call to bslstl::StdExceptUtil::throwOutOfRange
.Note that portions of the standard methods are implemented in Deque_Base
, which is parameterized on only VALUE_TYPE
in order to generate smaller debug strings.
This class:
BDEX
serializationconst
thread-safe For terminology see bsldoc_glossary .In addition, the following members offer a full guarantee of rollback: if an exception is thrown during the invocation of insert
, push_front
, or push_back
on a pre-existing object, the object is left in a valid state and its value is unchanged.
typedef ALLOCATOR bsl::deque< VALUE_TYPE, ALLOCATOR >::allocator_type |
typedef ConstIterator bsl::deque< VALUE_TYPE, ALLOCATOR >::const_iterator |
typedef AllocatorTraits::const_pointer bsl::deque< VALUE_TYPE, ALLOCATOR >::const_pointer |
typedef const VALUE_TYPE& bsl::deque< VALUE_TYPE, ALLOCATOR >::const_reference |
typedef bsl::reverse_iterator<ConstIterator> bsl::deque< VALUE_TYPE, ALLOCATOR >::const_reverse_iterator |
typedef std::ptrdiff_t bsl::deque< VALUE_TYPE, ALLOCATOR >::difference_type |
typedef Iterator bsl::deque< VALUE_TYPE, ALLOCATOR >::iterator |
typedef AllocatorTraits::pointer bsl::deque< VALUE_TYPE, ALLOCATOR >::pointer |
typedef VALUE_TYPE& bsl::deque< VALUE_TYPE, ALLOCATOR >::reference |
typedef bsl::reverse_iterator<Iterator> bsl::deque< VALUE_TYPE, ALLOCATOR >::reverse_iterator |
typedef std::size_t bsl::deque< VALUE_TYPE, ALLOCATOR >::size_type |
typedef VALUE_TYPE bsl::deque< VALUE_TYPE, ALLOCATOR >::value_type |
bsl::deque< VALUE_TYPE, ALLOCATOR >::deque | ( | ) |
|
explicit |
Create an empty deque. Optionally specify a basicAllocator
used to supply memory. If basicAllocator
is not supplied, a default-constructed object of the (template parameter) type ALLOCATOR
is used. If the type ALLOCATOR
is bsl::allocator
(the default), then basicAllocator
, if supplied, shall be convertible to bslma::Allocator *
. If the type ALLOCATOR
is bsl::allocator
and basicAllocator
is not supplied, the currently installed default allocator is used.
|
explicit |
Create a deque of the specified numElements
size whose every element is value-initialized. Optionally specify a basicAllocator
used to supply memory. If basicAllocator
is not supplied, a default-constructed object of the (template parameter) type ALLOCATOR
is used. If the type ALLOCATOR
is bsl::allocator
(the default), then basicAllocator
, if supplied, shall be convertible to bslma::Allocator *
. If the type ALLOCATOR
is bsl::allocator
and basicAllocator
is not supplied, the currently installed default allocator is used. Throw bsl::length_error
if numElements > max_size()
. This method requires that the (template parameter) VALUE_TYPE
be default-insertable
into this deque (see {Requirements on VALUE_TYPE
}).
bsl::deque< VALUE_TYPE, ALLOCATOR >::deque | ( | size_type | numElements, |
const VALUE_TYPE & | value, | ||
const ALLOCATOR & | basicAllocator = ALLOCATOR() |
||
) |
Create a deque of the specified numElements
size whose every element has the specified value
. Optionally specify a basicAllocator
used to supply memory. If basicAllocator
is not supplied, a default-constructed object of the (template parameter) type ALLOCATOR
is used. If the type ALLOCATOR
is bsl::allocator
(the default), then basicAllocator
, if supplied, shall be convertible to bslma::Allocator *
. If the type ALLOCATOR
is bsl::allocator
and basicAllocator
is not supplied, the currently installed default allocator is used. Throw bsl::length_error
if numElements > max_size()
. This method requires that the (template parameter) VALUE_TYPE
be copy-insertable
into this deque (see {Requirements on VALUE_TYPE
}).
bsl::deque< VALUE_TYPE, ALLOCATOR >::deque | ( | INPUT_ITERATOR | first, |
INPUT_ITERATOR | last, | ||
const ALLOCATOR & | basicAllocator = ALLOCATOR() |
||
) |
Create a deque initially containing copies of the values in the range starting at the specified first
and ending immediately before the specified last
iterators of the (template parameter) type INPUT_ITERATOR
. Optionally specify a basicAllocator
used to supply memory. If basicAllocator
is not supplied, a default-constructed object of the (template parameter) type ALLOCATOR
is used. If the type ALLOCATOR
is bsl::allocator
(the default), then basicAllocator
, if supplied, shall be convertible to bslma::Allocator *
. If the type ALLOCATOR
is bsl::allocator
and basicAllocator
is not supplied, the currently installed default allocator is used. Throw bsl::length_error
if the number of elements in [first .. last)
exceeds the size returned by max_size . The (template parameter) type INPUT_ITERATOR
shall meet the requirements of an input iterator defined in the C++11 standard [input.iterators] providing access to values of a type convertible to value_type
, and value_type
must be emplace-constructible
from *i
into this deque, where i
is a dereferenceable iterator in the range [first .. last)
(see {Requirements on VALUE_TYPE
}). The behavior is undefined unless first
and last
refer to a sequence of valid values where first
is at a position at or before last
.
bsl::deque< VALUE_TYPE, ALLOCATOR >::deque | ( | const deque< VALUE_TYPE, ALLOCATOR > & | original | ) |
Create a deque that has the same value as the specified original
object. Use the allocator returned by 'bsl::allocator_traits<ALLOCATOR>:: select_on_container_copy_construction(original.get_allocator())' to supply memory. If the (template parameter) type ALLOCATOR
is bsl::allocator
(the default), the currently installed default allocator is used. This method requires that the (template parameter) VALUE_TYPE
be copy-insertable
into this deque (see {Requirements on VALUE_TYPE
}).
bsl::deque< VALUE_TYPE, ALLOCATOR >::deque | ( | const deque< VALUE_TYPE, ALLOCATOR > & | original, |
const typename type_identity< ALLOCATOR >::type & | basicAllocator | ||
) |
Create a deque that has the same value as the specified original
object and that uses the specified basicAllocator
to supply memory. This method requires that the (template parameter) VALUE_TYPE
be copy-insertable
into this deque (see {Requirements on VALUE_TYPE
}). Note that a bslma::Allocator *
can be supplied for basicAllocator
if the (template parameter) type ALLOCATOR
is bsl::allocator
(the default).
bsl::deque< VALUE_TYPE, ALLOCATOR >::deque | ( | BloombergLP::bslmf::MovableRef< deque< VALUE_TYPE, ALLOCATOR > > | original | ) |
Create a deque having the same value as the specified original
object by moving (in constant time) the contents of original
to the new deque. The allocator associated with original
is propagated for use in the newly-created deque. original
is left in a valid but unspecified state.
bsl::deque< VALUE_TYPE, ALLOCATOR >::deque | ( | BloombergLP::bslmf::MovableRef< deque< VALUE_TYPE, ALLOCATOR > > | original, |
const typename type_identity< ALLOCATOR >::type & | basicAllocator | ||
) |
Create a deque having the same value as the specified original
object that uses the specified basicAllocator
to supply memory. The contents of original
are moved (in constant time) to the new deque if basicAllocator == original.get_allocator()
, and are move- inserted (in linear time) using basicAllocator
otherwise. original
is left in a valid but unspecified state. This method requires that the (template parameter) VALUE_TYPE
be move-insertable
into this deque (see {Requirements on VALUE_TYPE
}). Note that a bslma::Allocator *
can be supplied for basicAllocator
if the (template parameter) ALLOCATOR
is bsl::allocator
(the default).
bsl::deque< VALUE_TYPE, ALLOCATOR >::~deque | ( | ) |
deque &operator=(BloombergLP::bslmf::MovableRef< deque > rhs) BSLS_KEYWORD_NOEXCEPT_SPECIFICATION(AllocatorTraits void bsl::deque< VALUE_TYPE, ALLOCATOR >::assign | ( | INPUT_ITERATOR | first, |
INPUT_ITERATOR | last | ||
) |
Assign to this deque the values in the range starting at the specified first
and ending immediately before the specified last
iterators of the (template parameter) type INPUT_ITERATOR
. The (template parameter) type INPUT_ITERATOR
shall meet the requirements of an input iterator defined in the C++11 standard [input.iterators] providing access to values of a type convertible to value_type
, and value_type
must be copy-assignable
and emplace-constructible
from *i
into this deque, where i
is a dereferenceable iterator in the range [first .. last)
(see {Requirements on VALUE_TYPE
}). The behavior is undefined unless first
and last
refer to a sequence of valid values where first
is at a position at or before last
.
void bsl::deque< VALUE_TYPE, ALLOCATOR >::assign | ( | INPUT_ITERATOR | first, |
INPUT_ITERATOR | last | ||
) |
void bsl::deque< VALUE_TYPE, ALLOCATOR >::assign | ( | size_type | numElements, |
const VALUE_TYPE & | value | ||
) |
Assign to this object the value resulting from first clearing this deque and then appending the specified numElements
having the specified value
. This method requires that the (template parameter) VALUE_TYPE
be copy-assignable
and copy-insertable
into this deque (see {Requirements on VALUE_TYPE
}).
iterator bsl::deque< VALUE_TYPE, ALLOCATOR >::emplace | ( | const_iterator | position, |
Args &&... | arguments | ||
) |
Insert at the specified position
in this deque a newly created value_type
object, constructed by forwarding get_allocator()
(if required) and the specified (variable number of) arguments
to the corresponding constructor of value_type
, and return an iterator providing modifiable access to the newly created and inserted element. If an exception is thrown (other than by the copy constructor, move constructor, assignment operator, or move assignment operator of value_type
), this method has no effect. This method requires that the (template parameter) VALUE_TYPE
be move-insertable
into this deque and emplace-constructible
from arguments
(see {Requirements on VALUE_TYPE
}). The behavior is undefined unless position
is an iterator in the range [cbegin() .. cend()]
(both endpoints included).
deque< VALUE_TYPE, ALLOCATOR >::iterator bsl::deque< VALUE_TYPE, ALLOCATOR >::emplace | ( | const_iterator | position, |
Args &&... | arguments | ||
) |
reference bsl::deque< VALUE_TYPE, ALLOCATOR >::emplace_back | ( | Args &&... | arguments | ) |
Append to the back of this deque a newly created value_type
object, constructed by forwarding get_allocator()
(if required) and the specified (variable number of) arguments
to the corresponding constructor of value_type
. Return a reference providing modifiable access to the inserted element. If an exception is thrown (other than by the move constructor of a non-copy-insertable value_type
), this method has no effect. This method requires that the (template parameter) VALUE_TYPE
be move-insertable
into this deque and emplace-constructible
from arguments
(see {Requirements on VALUE_TYPE
}).
deque< VALUE_TYPE, ALLOCATOR >::reference bsl::deque< VALUE_TYPE, ALLOCATOR >::emplace_back | ( | Args &&... | arguments | ) |
reference bsl::deque< VALUE_TYPE, ALLOCATOR >::emplace_front | ( | Args &&... | arguments | ) |
Prepend to the front of this deque a newly created value_type
object, constructed by forwarding get_allocator()
(if required) and the specified (variable number of) arguments
to the corresponding constructor of value_type
. Return a reference providing modifiable access to the inserted element. If an exception is thrown (other than by the move constructor of a non-copy-insertable value_type
), this method has no effect. This method requires that the (template parameter) VALUE_TYPE
be move-insertable
into this deque and emplace-constructible
from arguments
(see {Requirements on VALUE_TYPE
}).
deque< VALUE_TYPE, ALLOCATOR >::reference bsl::deque< VALUE_TYPE, ALLOCATOR >::emplace_front | ( | Args &&... | arguments | ) |
deque< VALUE_TYPE, ALLOCATOR >::iterator bsl::deque< VALUE_TYPE, ALLOCATOR >::erase | ( | const_iterator | first, |
const_iterator | last | ||
) |
deque< VALUE_TYPE, ALLOCATOR >::iterator bsl::deque< VALUE_TYPE, ALLOCATOR >::erase | ( | const_iterator | position | ) |
Remove from this deque the element at the specified position
, and return an iterator providing modifiable access to the element immediately following the removed element, or the position returned by the method end
if the removed element was the last in the sequence. The behavior is undefined unless position
is an iterator in the range [cbegin() .. cend())
.
|
inline |
deque< VALUE_TYPE, ALLOCATOR >::iterator bsl::deque< VALUE_TYPE, ALLOCATOR >::insert | ( | const_iterator | position, |
BloombergLP::bslmf::MovableRef< value_type > | value | ||
) |
Insert at the specified position
in this deque the specified move-insertable value
, and return an iterator providing modifiable access to the newly inserted element. value
is left in a valid but unspecified state. If an exception is thrown (other than by the copy constructor, move constructor, assignment operator, or move assignment operator of value_type
), this method has no effect. This method requires that the (template parameter) VALUE_TYPE
be move-insertable
into this deque (see {Requirements on VALUE_TYPE
}). The behavior is undefined unless position
is an iterator in the range [cbegin() .. cend()]
(both endpoints included).
deque< VALUE_TYPE, ALLOCATOR >::iterator bsl::deque< VALUE_TYPE, ALLOCATOR >::insert | ( | const_iterator | position, |
const VALUE_TYPE & | value | ||
) |
Insert at the specified position
in this deque a copy of the specified value
, and return an iterator providing modifiable access to the newly inserted element. This method offers full guarantee of rollback in case an exception is thrown other than by the VALUE_TYPE
copy constructor or assignment operator. This method requires that the (template parameter) VALUE_TYPE
be copy-insertable
into this deque (see {Requirements on VALUE_TYPE
}). The behavior is undefined unless position
is an iterator in the range '[cbegin() .. cend()] (both endpoints included)'.
iterator bsl::deque< VALUE_TYPE, ALLOCATOR >::insert | ( | const_iterator | position, |
INPUT_ITERATOR | first, | ||
INPUT_ITERATOR | last | ||
) |
Insert at the specified position
in this deque the values in the range starting at the specified first
and ending immediately before the specified last
iterators of the (template parameter) type INPUT_ITERATOR
, and return an iterator providing modifiable access to the first element in the newly inserted sequence of elements. This method offers full guarantee of rollback in case an exception is thrown other than by the VALUE_TYPE
copy constructor or assignment operator. The (template parameter) type INPUT_ITERATOR
shall meet the requirements of an input iterator defined in the C++11 standard [input.iterators] providing access to values of a type convertible to value_type
, and value_type
must be emplace-constructible
from *i
into this deque, where i
is a dereferenceable iterator in the range [first .. last)
(see {Requirements on VALUE_TYPE
}). The behavior is undefined unless position
is an iterator in the range [cbegin() .. cend()]
(both endpoints included), and first
and last
refer to a sequence of valid values where first
is at a position at or before last
.
|
inline |
deque< VALUE_TYPE, ALLOCATOR >::iterator bsl::deque< VALUE_TYPE, ALLOCATOR >::insert | ( | const_iterator | position, |
size_type | numElements, | ||
const VALUE_TYPE & | value | ||
) |
Insert at the specified position
in this deque the specified numElements
copies of the specified value
, and return an iterator providing modifiable access to the first element in the newly inserted sequence of elements. This method offers full guarantee of rollback in case an exception is thrown other than by the VALUE_TYPE
copy constructor or assignment operator. This method requires that the (template parameter) VALUE_TYPE
be copy-insertable
into this deque (see {Requirements on VALUE_TYPE
}). The behavior is undefined unless position
is an iterator in the range [cbegin() .. cend()]
(both endpoints included).
|
inline |
Return the maximum possible size of this deque. Note that this is a theoretical maximum (such as the maximum value that can be held by size_type
). Also note that any request to create or enlarge a deque to a size greater than max_size()
is guaranteed to raise a bsl::length_error
exception.
deque< VALUE_TYPE, ALLOCATOR > & bsl::deque< VALUE_TYPE, ALLOCATOR >::operator= | ( | const deque< VALUE_TYPE, ALLOCATOR > & | rhs | ) |
Assign to this object the value of the specified rhs
object, propagate to this object the allocator of rhs
if the ALLOCATOR
type has trait propagate_on_container_copy_assignment
, and return a reference providing modifiable access to this object. If an exception is thrown, *this
is left in a valid but unspecified state. This method requires that the (template parameter) VALUE_TYPE
be copy-assignable
and copy-insertable
into this deque (see {Requirements on VALUE_TYPE
}).
void bsl::deque< VALUE_TYPE, ALLOCATOR >::pop_back | ( | ) |
Erase the last element from this deque. The behavior is undefined if this deque is empty.
void bsl::deque< VALUE_TYPE, ALLOCATOR >::pop_front | ( | ) |
Erase the first element from this deque. The behavior is undefined if this deque is empty.
deque< VALUE_TYPE, ALLOCATOR >::size_type bsl::deque< VALUE_TYPE, ALLOCATOR >::privateAppend | ( | INPUT_ITERATOR | first, |
INPUT_ITERATOR | last, | ||
std::input_iterator_tag | |||
) |
deque< VALUE_TYPE, ALLOCATOR >::size_type bsl::deque< VALUE_TYPE, ALLOCATOR >::privateAppend | ( | INPUT_ITERATOR | first, |
INPUT_ITERATOR | last, | ||
std::random_access_iterator_tag | |||
) |
|
inline |
deque< VALUE_TYPE, ALLOCATOR >::size_type bsl::deque< VALUE_TYPE, ALLOCATOR >::privatePrepend | ( | INPUT_ITERATOR | first, |
INPUT_ITERATOR | last, | ||
std::bidirectional_iterator_tag | |||
) |
deque< VALUE_TYPE, ALLOCATOR >::size_type bsl::deque< VALUE_TYPE, ALLOCATOR >::privatePrepend | ( | INPUT_ITERATOR | first, |
INPUT_ITERATOR | last, | ||
std::input_iterator_tag | tag | ||
) |
deque< VALUE_TYPE, ALLOCATOR >::size_type bsl::deque< VALUE_TYPE, ALLOCATOR >::privatePrepend | ( | INPUT_ITERATOR | first, |
INPUT_ITERATOR | last, | ||
std::random_access_iterator_tag | |||
) |
void bsl::deque< VALUE_TYPE, ALLOCATOR >::push_back | ( | BloombergLP::bslmf::MovableRef< value_type > | value | ) |
Append to the back of this deque the specified move-insertable value
. value
is left in a valid but unspecified state. If an exception is thrown (other than by the move constructor of a non-copy-insertable value_type
), this method has no effect. This method requires that the (template parameter) VALUE_TYPE
be move-insertable
into this deque (see {Requirements on VALUE_TYPE
}).
void bsl::deque< VALUE_TYPE, ALLOCATOR >::push_back | ( | const VALUE_TYPE & | value | ) |
Append to the back of this deque a copy of the specified value
. This method offers full guarantee of rollback in case an exception is thrown. This method requires that the (template parameter) VALUE_TYPE
be copy-constructible
(see {Requirements on VALUE_TYPE
}).
void bsl::deque< VALUE_TYPE, ALLOCATOR >::push_front | ( | BloombergLP::bslmf::MovableRef< value_type > | value | ) |
Prepend to the front of this deque the specified move-insertable value
. value
is left in a valid but unspecified state. If an exception is thrown (other than by the move constructor of a non-copy-insertable value_type
), this method has no effect. This method requires that the (template parameter) VALUE_TYPE
be move-insertable
into this deque (see {Requirements on VALUE_TYPE
}).
void bsl::deque< VALUE_TYPE, ALLOCATOR >::push_front | ( | const VALUE_TYPE & | value | ) |
Prepend to the front of this deque a copy of the specified value
. This method offers full guarantee of rollback in case an exception is thrown. This method requires that the (template parameter) VALUE_TYPE
be copy-constructible
(see {Requirements on VALUE_TYPE
}).
void bsl::deque< VALUE_TYPE, ALLOCATOR >::reserve | ( | size_type | numElements | ) |
Change the capacity of this deque such that, after this method returns, iterators remain valid provided that no more than the specified numElements
objects are pushed to the front or back of the deque after this call. If it is already possible to push numElements
objects to either end of this deque without invalidating iterators, this method has no effect. Note that inserting elements into the deque may still incur memory allocation. Also note that this method, if it has any effect, will invalidate iterators initialized prior to the call. Also note that this method is not part of the C++ standard.
void bsl::deque< VALUE_TYPE, ALLOCATOR >::resize | ( | size_type | newSize | ) |
void bsl::deque< VALUE_TYPE, ALLOCATOR >::resize | ( | size_type | newSize, |
const VALUE_TYPE & | value | ||
) |
Change the size of this deque to the specified newSize
. Erase size() - newSize
elements at the back if newSize < size()
. Append newSize - size()
elements at the back having the optionally specified value
if newSize > size()
; if value
is not specified, value-initialized objects of the (template parameter) VALUE_TYPE
are emplaced. This method has no effect if newSize == size()
. Throw bsl::length_error
if newSize > max_size()
.
void bsl::deque< VALUE_TYPE, ALLOCATOR >::shrink_to_fit | ( | ) |
Minimize the memory used by this deque to the extent possible without moving any contained elements. If an exception is thrown, the value of this object is unchanged. Note that this method has no effect on the memory used by individual elements of the (template parameter) VALUE_TYPE
.
|
friend |
|
friend |
|
friend |
void bsl::deque< VALUE_TYPE, ALLOCATOR >::clear |
Remove from this deque the sequence of elements starting at the specified first
position and ending before the specified last
position, and return an iterator providing modifiable access to the element immediately following the last removed element, or the position returned by the method end
if the removed elements were last in the sequence. The behavior is undefined unless first
is an iterator in the range [cbegin() .. cend()]
(both endpoints included) and last
is an iterator in the range [first .. cend()]
(both endpoints included). Remove all elements from this deque making its size 0. Note that although this deque is empty after this method returns, it preserves the same capacity it had before the method was called.