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 起) |
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)) 代替。
该函数的目的是允许 范围 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++ 标准。
DR | 应用于 | 已发布的行为 | 正确行为 |
---|---|---|---|
LWG 2058 | C++11 | 1. begin() 要求支持替换类型2. 返回的迭代器何时失效未指定 |
1. 不需要 2. 指定 |
[编辑] 另请参见
(C++11) |
专门化 std::end (函数模板) |