Namespaces
Variants

std::forward_list<T,Allocator>:: assign_range

From cppreference.net

template < container-compatible-range < T > R >
void assign_range ( R && rg ) ;
(C++23以降)
(constexprはC++26以降)

コンテナ内の要素を rg 内の各要素のコピーで置き換えます。

すべてのイテレータ( end() イテレータを含む)および要素へのすべての参照は無効化されます。

範囲内の各イテレータは、 rg 正確に1回デリファレンスされます。

rg * this とオーバーラップする場合、動作は未定義です。

目次

パラメータ

rg - コンテナの要素型に変換可能な参照型を持つ input_range
型要件
-
std:: assignable_from < T & , ranges:: range_reference_t < R >> がモデル化されない場合、プログラムは不適格となる。
-
T * ranges:: begin ( rg ) から forward_list への EmplaceConstructible でない場合、動作は未定義である。

注記

機能テスト マクロ 標準 機能
__cpp_lib_containers_ranges 202202L (C++23) レンジ対応 構築と挿入

#include <algorithm>
#include <cassert>
#include <forward_list>
#include <list>
int main()
{
    const auto source = std::list{2, 7, 1};
    auto destination = std::forward_list{3, 1, 4};
#ifdef __cpp_lib_containers_ranges
    destination.assign_range(source);
#else
    destination.assign(source.cbegin(), source.cend());
#endif
    assert(std::ranges::equal(source, destination));
}

関連項目

要素の後に要素の範囲を挿入する
(公開メンバ関数)
先頭に要素の範囲を追加する
(公開メンバ関数)
コンテナに値を割り当てる
(公開メンバ関数)
コンテナに値を割り当てる
(公開メンバ関数)