std::span<T,Extent>:: operator=
|
constexpr
span
&
operator
=
(
const
span
&
other
)
noexcept
=
default
;
|
(depuis C++20) | |
Assigne other à * this . Cet opérateur d'assignation par défaut effectue une copie superficielle du pointeur de données et de la taille, c'est-à-dire qu'après un appel à cette fonction, data ( ) == other. data ( ) et size ( ) == other. size ( ) .
Table des matières |
Paramètres
| autre | - | un autre span à copier |
Valeur de retour
* this
Exemple
#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 << "dynamique"; 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)); // Vérifier que l'assignation effectue une copie superficielle. s1 = s2; (s1.data() == s2.data() && s1.size() == s2.size()) ? print("s1 = s2; est une copie superficielle !") : print("s1 = s2; est une copie profonde !"); print("s1", s1); print("Remplir s1 avec 5 :"); std::ranges::fill(s1, 5); // s2 est également 'mis à jour' car s1 et s2 pointent vers les mêmes données 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; // ERREUR : aucune correspondance pour 'operator=' static_1 = static_2; // OK : mêmes dimensions = 4 // static_1 = static_3; // ERROR: différentes dimensions : 4 et 3 }
Sortie :
s1[6] { 3 3 3 3 3 3 } étendue = 6, sizeof = 8
s2[6] { 4 4 4 4 4 4 } étendue = 6, sizeof = 8
s1 = s2; est une copie superficielle !
s1[6] { 4 4 4 4 4 4 }
Remplir s1 avec 5 :
s1[6] { 5 5 5 5 5 5 }
s2[6] { 5 5 5 5 5 5 }
dynamic_1[4] { 1 2 3 4 } étendue = dynamique, sizeof = 16
dynamic_2[3] { 2 3 4 } étendue = dynamique, sizeof = 16
static_1[4] { 1 2 3 4 } étendue = 4, sizeof = 8
static_2[4] { 2 3 4 5 } étendue = 4, sizeof = 8
static_3[3] { 3 4 5 } étendue = 3, sizeof = 8
Voir aussi
construit le
span
(fonction membre publique) |
|
|
accès direct au stockage contigu sous-jacent
(fonction membre publique) |
|
|
retourne le nombre d'éléments
(fonction membre publique) |