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;   // ОШИБКА: разные размерности: 4 и 3
}

Вывод:

s1[6] { 3 3 3 3 3 3 } extent = 6, sizeof = 8
s2[6] { 4 4 4 4 4 4 } extent = 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 } extent = dynamic, sizeof = 16
dynamic_2[3] { 2 3 4 } extent = dynamic, sizeof = 16
static_1[4] { 1 2 3 4 } extent = 4, sizeof = 8
static_2[4] { 2 3 4 5 } extent = 4, sizeof = 8
static_3[3] { 3 4 5 } extent = 3, sizeof = 8

Смотрите также

создает span
(публичная функция-член)
прямой доступ к базовому непрерывному хранилищу
(публичная функция-член)
возвращает количество элементов
(публичная функция-член)