Namespaces
Variants

std::span<T,Extent>:: operator=

From cppreference.net
constexpr span & operator = ( const span & other ) noexcept = default ;
(C++20以降)

other * this に代入します。このデフォルトの代入演算子はデータポインタとサイズの浅いコピーを実行します。つまり、この関数の呼び出し後、 data ( ) == other. data ( ) かつ size ( ) == other. size ( ) となります。

目次

パラメータ

その他 - コピー元となる別のスパン

戻り値

* this

#include <algorithm>
#include <array>
#include <cassert>
#include <cstddef>
#include <iostream>
#include <span>
#include <string_view>
void print(std::string_view info = "", std::span<const int> span = {},
           std::size_t extent = 0, std::size_t size_of = 0)
{
    if (span.empty())
    {
        std::cout << info << '\n';
        return;
    }
    std::cout << info << '[' << span.size() << "] {";
    std::ranges::for_each(span, [](const int x) { std::cout << ' ' << x; });
    std::cout << " }";
    if (extent)
    {
        std::cout << " extent = ";
        if (extent == std::dynamic_extent)
            std::cout << "dynamic";
        else
            std::cout << extent;
    }
    if (size_of)
        std::cout << ", sizeof = " << size_of;
    std::cout << '\n';
}
int main()
{
    std::array<int,6> a1;
    std::array<int,6> a2;
    a1.fill(3);
    a2.fill(4);
    auto s1 = std::span(a1);
    auto s2 = std::span(a2);
    print("s1", s1, s1.extent, sizeof(s1));
    print("s2", s2, s2.extent, sizeof(s2));
    // 代入が浅いコピーを実行することを確認する。
    s1 = s2;
    (s1.data() == s2.data() && s1.size() == s2.size())
        ? print("s1 = s2; はシャローコピーです!")
        : print("s1 = s2; はディープコピーです!");
    print("s1", s1);
    print("s1 を 5 で埋める:");
    std::ranges::fill(s1, 5);
    // s2も'更新'されます。s1とs2が同じデータを指しているため
    assert(std::ranges::equal(s1, s2));
    print("s1", s1);
    print("s2", s2);
    print();
    int a3[]{1, 2, 3, 4};
    int a4[]{2, 3, 4, 5};
    int a5[]{3, 4, 5};
    std::span<int, std::dynamic_extent> dynamic_1{a3};
    std::span<int, std::dynamic_extent> dynamic_2{a4, 3};
    std::span<int, 4> static_1{a3};
    std::span<int, 4> static_2{a4};
    std::span<int, 3> static_3{a5};
    print("dynamic_1", dynamic_1, dynamic_1.extent, sizeof(dynamic_1));
    print("dynamic_2", dynamic_2, dynamic_2.extent, sizeof(dynamic_2));
    print("static_1", static_1, static_1.extent, sizeof(static_1));
    print("static_2", static_2, static_2.extent, sizeof(static_2));
    print("static_3", static_3, static_3.extent, sizeof(static_3));
    dynamic_1 = dynamic_2; // OK
    dynamic_1 = static_1;  // OK
//  static_1 = dynamic_1;  // エラー: ‘operator=’ の一致するオペレータが見つかりません
    static_1 = static_2;   // OK: 同じエクステント = 4
//  static_1 = static_3;   // ERROR: 異なる範囲: 4 と 3
}

出力:

s1[6] { 3 3 3 3 3 3 } 要素数 = 6, sizeof = 8
s2[6] { 4 4 4 4 4 4 } 要素数 = 6, sizeof = 8
s1 = s2; はシャローコピーです!
s1[6] { 4 4 4 4 4 4 }
s1を5で埋める:
s1[6] { 5 5 5 5 5 5 }
s2[6] { 5 5 5 5 5 5 }
dynamic_1[4] { 1 2 3 4 } 要素数 = 動的, sizeof = 16
dynamic_2[3] { 2 3 4 } 要素数 = 動的, sizeof = 16
static_1[4] { 1 2 3 4 } 要素数 = 4, sizeof = 8
static_2[4] { 2 3 4 5 } 要素数 = 4, sizeof = 8
static_3[3] { 3 4 5 } 要素数 = 3, sizeof = 8

関連項目

span を構築する
(公開メンバ関数)
基盤となる連続ストレージへの直接アクセス
(公開メンバ関数)
要素数を返す
(公開メンバ関数)