命名空间
变体
操作

std::end(std::valarray)

来自 cppreference.com
< cpp‎ | numeric‎ | valarray
 
 
 
 
template< class T >
/* 见下文 */ end( valarray<T>& v );
(1) (自 C++11 起)
template< class T >
/* 见下文 */ end( const valarray<T>& v );
(2) (自 C++11 起)

valarraystd::end 重载返回一个未指定类型的迭代器,该迭代器指向数值数组中最后一个元素的下一个位置。

1) 返回类型必须
(自 C++20 起)
  • 具有成员类型 value_type,其值为 T,并且
  • 具有成员类型 reference,其值为 T&
2) 返回类型必须
(自 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. 已指定

[编辑] 参见

重载 std::begin
(函数模板) [编辑]