std::begin(std::valarray)
来自 cppreference.cn
template< class T > /* see below */ begin( valarray<T>& v ); |
(1) | (since C++11) |
template< class T > /* see below */ begin( const valarray<T>& v ); |
(2) | (since C++11) |
valarray
的 std::begin 重载返回一个未指定类型的迭代器,该迭代器指向数值数组中的第一个元素。
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++ 标准。
DR | 应用于 | 已发布行为 | 正确行为 |
---|---|---|---|
LWG 2058 | C++11 | 1. begin() 被要求支持替换类型2. 未指定返回的迭代器何时失效 |
1. 不需要 2. 已指定 |
[编辑] 参见
(C++11) |
特化 std::end (函数模板) |