std::mask_array<T>:: operator=
From cppreference.net
<
cpp
|
numeric
|
valarray
|
mask array
|
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) | |
Присваивает значения всем указанным элементам.
1)
Присваивает
value
всем элементам.
2)
Присваивает элементы
val_arr
соответствующим элементам
*
this
.
3)
Присваивает выбранные элементы из
other_arr
соответствующим элементам
*
this
.
Содержание |
Параметры
| value | - | значение, присваиваемое всем указанным элементам |
| val_arr | - | std::valarray для присваивания |
| other_arr | - | std::mask_array для присваивания |
Возвращаемое значение
1,2)
(нет)
3)
*
this
Пример
Запустить этот код
#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); }
Вывод:
1 0 3 0 5 0 7 0 -1 2 -2 4 -3 6 -4 8 1 1 3 3 5 5 7 7
Отчёты о дефектах
Следующие отчеты об изменениях в поведении, содержащие описания дефектов, были применены ретроактивно к ранее опубликованным стандартам C++.
| DR | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| LWG 123 | C++98 | overload (2) was non-const | made const |
| LWG 253 | C++98 | the copy assignment operator was private | made public |
| LWG 621 | C++98 | the copy assignment operator was non-const | made const |