Namespaces
Variants

std::mask_array<T>:: operator=

From cppreference.net

void operator = ( const T & value ) const ;
(1)
void operator = ( const std:: valarray < T > & val_arr ) const ;
(2)
const mask_array & operator = ( const mask_array & other_arr ) const ;
(3)

Attribue des valeurs à tous les éléments référencés.

1) Affecte la valeur value à tous les éléments.
2) Affecte les éléments de val_arr aux éléments référencés de * this .
3) Affecte les éléments sélectionnés de other_arr aux éléments référencés de * this .

Table des matières

Paramètres

value - une valeur à assigner à tous les éléments référencés
val_arr - std::valarray à assigner
other_arr - std::mask_array à assigner

Valeur de retour

1,2) (aucun)
3) * this

Exemple

#include <iomanip>
#include <iostream>
#include <valarray>
void print(std::valarray<int> const& v)
{
    for (int e : v)
        std::cout << std::setw(2) << e << ' ';
    std::cout << '\n';
}
int main()
{
    const auto init = {1, 2, 3, 4, 5, 6, 7, 8};
    std::valarray<int> v;
    v = init;
    v[(v % 2) == 0] = 0; // (1)
    print(v);
    v = init;
    v[(v % 2) == 1] = std::valarray<int>{-1, -2, -3, -4}; // (2)
    print(v);
    v = init;
    v[(v % 2) == 0] = v[(v % 2) == 1]; // (3)
    print(v);
}

Sortie :

 1  0  3  0  5  0  7  0 
-1  2 -2  4 -3  6 -4  8 
 1  1  3  3  5  5  7  7

Rapports de défauts

Les rapports de défauts modifiant le comportement suivants ont été appliqués rétroactivement aux normes C++ précédemment publiées.

DR Appliqué à Comportement publié Comportement corrigé
LWG 123 C++98 la surcharge (2) était non-const rendue const
LWG 253 C++98 l'opérateur d'affectation par copie était privé rendu public
LWG 621 C++98 l'opérateur d'affectation par copie était non-const rendu const