std::end(std::valarray)
来自 cppreference.com
template< class T > /* 见下文 */ end( valarray<T>& v ); |
(1) | (自 C++11 起) |
template< class T > /* 见下文 */ end( const valarray<T>& v ); |
(2) | (自 C++11 起) |
valarray
的 std::end 重载返回一个未指定类型的迭代器,该迭代器指向数值数组中最后一个元素的下一个位置。
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
参数的函数不同,end()
无法接受可能由涉及 valarrays 的表达式返回的替换类型(例如表达式模板生成的类型):std::end(v1 + v2) 不可移植,必须使用 std::end(std::valarray<T>(v1 + v2))。
此函数的目的是允许 范围 for 循环 与 valarrays 一起工作,而不是提供容器语义。
[编辑] 示例
运行此代码
#include <algorithm> #include <iostream> #include <valarray> int main() { const std::valarray<char> va { 'H', 'e', 'l', 'l', 'o', ',', ' ', 'C', '+', '+', '!', '\n' }; std::for_each(std::begin(va), std::end(va), [](char c){ std::cout << c; }); }
输出
Hello, C++!
[编辑] 缺陷报告
以下更改行为的缺陷报告已追溯应用于先前发布的 C++ 标准。
DR | 应用于 | 发布的行为 | 正确行为 |
---|---|---|---|
LWG 2058 | C++11 | 1. end() 要求支持替换类型2. 返回的迭代器何时失效未指定 |
1. 不需要 2. 已指定 |
[编辑] 参见
(C++11) |
重载 std::begin (函数模板) |