名前空間
変種
操作

std::begin(std::valarray)

From cppreference.com
< cpp‎ | numeric‎ | valarray
 
 
 
 
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) 返される型は
(C++20以降)
  • メンバー型 value_typeT であり、
  • メンバー型 referenceT& でなければなりません。
2) 返される型は
(C++20以降)
  • メンバー型 value_typeT であり、
  • メンバー型 referenceconst 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. 指定された

[編集] 関連項目

std::end を特殊化する
(function template) [編集]
English 日本語 中文(简体) 中文(繁體)