std::begin(std::valarray)
来自cppreference.com
template< class T > /* 见下文 */ begin( valarray<T>& v ); |
(1) | (C++11 起) |
template< class T > /* 见下文 */ begin( const valarray<T>& v ); |
(2) | (C++11 起) |
std::begin 对 valarray
的重载返回指代数值数组中首元素的未指定类型迭代器。
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. 已指定 |
参阅
(C++11) |
特化的 std::end (函数模板) |