std::begin(std::valarray)

来自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 起)

std::beginvalarray 的重载返回指代数值数组中首元素的未指定类型迭代器。

1) 返回类型需要满足以下条件:
(C++20 起)
  • 具有成员类型 value_type,并且它是 T
  • 具有成员类型 reference,并且它是 T&
2) 返回类型需要满足以下条件:
(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)) 代替。

此函数的意图是允许范围 for 循环能用于 valarray,而不是提供容器语义。

示例

#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++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 2058 C++11 1. begin() 需要支持替换类型
2. 未指定返回的迭代器会在什么时候失效
1. 不需要
2. 已指定

参阅

特化的 std::end
(函数模板)