Namespaces
Variants
Actions

std::inplace_vector<T,N>::assign_range

From cppreference.com
 
 
 
 
template<container-compatible-range<T> R >
constexprvoid assign_range( R&& rg );
(since C++26)

Replaces elements in the container with a copy of each element in rg.

Each iterator in the range rg is dereferenced exactly once.

If rg overlaps with *this, the behavior is undefined.

Contents

[edit]Parameters

rg - an input_range with reference type convertible to the element type of the container
Type requirements
-
If std::assignable_from<T&, ranges::range_reference_t<R>> is not modeled, the program is ill-formed.
-
If T is not EmplaceConstructible into inplace_vector from *ranges::begin(rg), the behavior is undefined.

Exceptions

[edit]Example

#include <algorithm>#include <cassert>#include <initializer_list>#include <inplace_vector>#include <iostream>#include <new>   int main(){constauto source ={1, 2, 3};std::inplace_vector<int, 4> destination{4, 5}; destination.assign_range(source);assert(std::ranges::equal(destination, source));   try{constauto bad ={-1, -2, -3, -4, -5}; destination.assign_range(bad);// throws: bad.size() > destination.capacity()}catch(conststd::bad_alloc& ex){std::cout<< ex.what()<<'\n';}}

Possible output:

std::bad_alloc

[edit]See also

inserts a range of elements
(public member function)
adds a range of elements to the end
(public member function)
assigns values to the container
(public member function)
assigns values to the container
(public member function)
close