std::begin(std::valarray)
From cppreference.com
| template< class T > /* 以下参照 */ begin( valarray<T>& v ); |
(1) | (C++11以降) |
| template< class T > /* 以下参照 */ begin( const valarray<T>& v ); |
(2) | (C++11以降) |
valarray に対する std::begin のオーバーロードは、数値配列の最初の要素を参照する、型が未指定のイテレータを返します。
1) 返される型は
- ミュータブルな LegacyRandomAccessIterator の要件を満たし、
|
(C++20以降) |
- メンバー型
value_typeはTであり、 - メンバー型
referenceはT&でなければなりません。
2) 返される型は
- コンスタントな LegacyRandomAccessIterator の要件を満たし、
|
(C++20以降) |
- メンバー型
value_typeはTであり、 - メンバー型
referenceはconst T&でなければなりません。
この関数から返されるイテレータは、v に対してメンバー関数 resize() が呼び出されたとき、または v の寿命が尽きたときに無効になります(いずれかが先に発生した場合)。
目次 |
[編集] パラメータ
| v | - | 数値配列 |
[編集] 戻り値
数値配列の最初の値へのイテレータ。
[編集] 例外
実装定義の例外をスローする場合があります。
[編集] 注記
std::valarray 引数を受け取る他の関数とは異なり、begin() は、valarray を含む式から返される可能性のある置換型(式テンプレートによって生成される型など)を受け入れることはできません。std::begin(v1 + v2) は移植性がなく、代わりに std::begin(std::valarray<T>(v1 + v2)) を使用する必要があります。
この関数の意図は、valarray で範囲 for ループ を使用できるようにすることであり、コンテナとしてのセマンティクスを提供することではありません。
[編集] 例
このコードを実行
#include <algorithm> #include <iostream> #include <valarray> void show(const std::valarray<int>& v) { std::for_each(std::begin(v), std::end(v), [](int c) { std::cout << c << ' '; }); std::cout << '\n'; }; int main() { const std::valarray<int> x{47, 70, 37, 52, 90, 23, 17, 33, 22, 16, 21, 4}; const std::valarray<int> y{25, 31, 71, 56, 21, 21, 15, 34, 21, 27, 12, 6}; show(x); show(y); const std::valarray<int> z{x + y}; for (char c : z) std::cout << c; }
出力
47 70 37 52 90 23 17 33 22 16 21 4 25 31 71 56 21 21 15 34 21 27 12 6 Hello, C++!
[編集] 不具合報告
以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。
| DR | 適用対象 | 公開された動作 | 正しい動作 |
|---|---|---|---|
| LWG 2058 | C++11 | 1. begin() は置換型をサポートする必要があった2. 返されたイテレータが無効になる時期が未指定であった |
1. 必要ない 2. 指定された |
[編集] 関連項目
| (C++11) |
std::end を特殊化する (function template) |