std::inplace_vector<T,N>::try_append_range - cppreference.com
From cppreference.com
|
|
(since C++26) | |
Appends copies of initial elements in rg before end(), until all elements are inserted or the internal storage is exhausted (i.e. size() == capacity() is true).
All iterators and references remain valid. The end() iterator is invalidated.
Each iterator in rg is dereferenced at most once.
Parameters
Return value
An iterator pointing to the first element of rg that was not inserted into *this, or ranges::end(rg) if no such element exists.
Complexity
Linear in the number of elements inserted.
Exceptions
Any exception thrown by initialization of inserted element.
inplace_vector provides the basic exception safety guarantee, i.e., all elements of the container before the call are preserved, and all already inserted elements (before the exception, if any) are also preserved.
Notes
Example
#include <cassert> #include <initializer_list> #include <inplace_vector> int main() { using I = std::inplace_vector<int, 8>; auto nums = I{1, 2, 3}; const auto rg = {-1, -2, -3}; auto it = nums.try_append_range(rg); assert(nums.size() == 6); assert((nums == I{1, 2, 3, -1, -2, -3})); assert(it == rg.end()); it = nums.try_append_range(rg); assert(nums.size() == 8); assert((nums == I{1, 2, 3, -1, -2, -3, -1, -2})); assert(it == rg.begin() + 2); }
See also
| adds a range of elements to the end (public member function) [edit] | |
| adds an element to the end (public member function) [edit] | |
| tries to add an element to the end (public member function) [edit] | |
| unconditionally adds an element to the end (public member function) [edit] | |
| constructs an element in-place at the end (public member function) [edit] | |
| tries to construct an element in-place at the end (public member function) [edit] | |
| unconditionally constructs an element in-place at the end (public member function) [edit] | |
| removes the last element (public member function) [edit] | |
| creates a std::back_insert_iterator of type inferred from the argument (function template) [edit] |