std::valarray<T>::operator+=,-=,*=,/=,%=,&=,|=,<<=,>>= - cppreference.com
提供: cppreference.com
<tbody> </tbody>
|
|
(1) | |
|
|
(2) | |
数値配列内の要素それぞれに複合代入演算子を適用します。
1) それぞれの要素はその要素の以前の値と v 内の対応する要素に対応する演算子を適用することによって取得された値が代入されます。
size() != v.size() の場合、動作は未定義です。
v 内のいずれかの値が代入中に計算され、 *this 内のいずれかの値に依存する場合、つまり、代入の右側の式が代入の左側の変数を参照する場合、動作は未定義です。
2) それぞれの要素はその要素の以前の値と val の値に対応する演算子を適用することによって取得された値が代入されます。
引数
戻り値
*this。
例外
(なし)
ノート
それぞれの演算子は以下の要件を満たす場合にのみ実体化できます。
- 指定された演算子が型
Tに適用可能である。 - 結果の値が曖昧さなく
T(1-3) またはbool(4) に変換可能である。
- 指定された演算子が型
関数は std::valarray と異なる戻り値の型を使用して実装することができます。 この場合、その置換型は以下の性質を持ちます。
- std::valarray のすべての
constメンバ関数が提供されます。 - 置換型から std::valarray、
std::slice_array、std::gslice_array、std::mask_arrayおよびstd::indirect_arrayが構築できます。 const std::valarray&型の引数を取るすべての関数 ( begin() と end() を除く) (C++11以上) は置換型も受理するべきです。const std::valarray&型の引数を2つ取るすべての関数はconst std::valarray&と置換型のすべての組み合わせを受理するべきです。- 戻り値の型は最も深くネストした引数型より3段以上ネストしたテンプレートを追加しません。
- std::valarray のすべての