(1) | ||
iterator insert( iterator pos, const T& value ); | (until C++11) | |
iterator insert( const_iterator pos, const T& value ); | (since C++11) | |
iterator insert( const_iterator pos, T&& value ); | (2) | (since C++11) |
(3) | ||
void insert( iterator pos, size_type count, const T& value ); | (until C++11) | |
iterator insert( const_iterator pos, size_type count, const T& value ); | (since C++11) | |
(4) | ||
template< class InputIt > void insert( iterator pos, InputIt first, InputIt last); | (until C++11) | |
template< class InputIt > iterator insert( const_iterator pos, InputIt first, InputIt last ); | (since C++11) | |
iterator insert( const_iterator pos, std::initializer_list<T> ilist ); | (5) | (since C++11) |
Inserts elements at the specified location in the container.
value
before pos
count
copies of the value
before pos
[first, last)
before pos
. This overload has the same effect as overload (3) if InputIt is an integral type. | (until C++11) |
This overload only participates in overload resolution if InputIt qualifies as LegacyInputIterator, to avoid ambiguity with the overload (3). | (since C++11) |
first
and last
are iterators into *this
. ilist
before pos
.No iterators or references are invalidated.
pos | - | iterator before which the content will be inserted. pos may be the end() iterator |
value | - | element value to insert |
first, last | - | the range of elements to insert, can't be iterators into container for which insert is called |
ilist | - | initializer list to insert the values from |
Type requirements | ||
-T must meet the requirements of CopyInsertable in order to use overload (1). |
||
-T must meet the requirements of MoveInsertable in order to use overload (2). |
||
-T must meet the requirements of CopyAssignable and CopyInsertable in order to use overload (3). |
||
-T must meet the requirements of EmplaceConstructible in order to use overload (4,5). |
value
pos
if count==0
.pos
if first==last
.pos
if ilist
is empty.count
std::distance(first, last)
ilist.size()
If an exception is thrown, there are no effects (strong exception guarantee).
(C++11) | constructs element in-place (public member function) |
inserts an element to the beginning (public member function) |
|
adds an element to the end (public member function) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
http://en.cppreference.com/w/cpp/container/list/insert