命名空间
变体
操作

std::end, std::cend

来自 cppreference.com
< cpp‎ | iterator
 
 
迭代器库
迭代器概念
迭代器原语
算法概念和实用程序
间接可调用概念
通用算法要求
(C++20)
(C++20)
(C++20)
实用程序
(C++20)
迭代器适配器
范围访问
(C++11)(C++14)
(C++14)(C++14)  
endcend
(C++11)(C++14)
(C++14)(C++14)  
(C++17)(C++20)
(C++17)
(C++17)
 
在头文件 <array> 中定义
在头文件 <deque> 中定义
在头文件 <flat_map> 中定义
在头文件 <flat_set> 中定义
在头文件 <forward_list> 中定义
在头文件 <inplace_vector> 中定义
在头文件 <iterator> 中定义
在头文件 <list> 中定义
在头文件 <map> 中定义
在头文件 <regex> 中定义
在头文件 <set> 中定义
在头文件 <span> 中定义
在头文件 <string> 中定义
在头文件 <string_view> 中定义
在头文件 <unordered_map> 中定义
在头文件 <unordered_set> 中定义
在头文件 <vector> 中定义
template< class C >
auto end( C& c ) -> decltype(c.end());
(1) (自 C++11 起)
(自 C++17 起为 constexpr)
template< class C >
auto end( const C& c ) -> decltype(c.end());
(2) (自 C++11 起)
(自 C++17 起为 constexpr)
(3)
template< class T, std::size_t N >
T* end( T (&array)[N] );
(自 C++11 起)
(直到 C++14)
template< class T, std::size_t N >
constexpr T* end( T (&array)[N] ) noexcept;
(自 C++14 起)
template< class C >

constexpr auto cend( const C& c ) noexcept(/* 见下文 */)

    -> decltype(std::end(c));
(4) (自 C++14 起)

返回指向给定范围末尾(即最后一个元素之后的元素)的迭代器。

1,2) 返回 c.end(),它通常是代表 c 的序列末尾后的一个迭代器。
1) 如果 C 是一个标准 容器,则返回一个 C::iterator 对象。
2) 如果 C 是一个标准 容器,则返回一个 C::const_iterator 对象。
3) 返回指向 array 末尾的指针。
4) 返回 std::end(c),其中 c 始终被视为 const 限定。
如果 C 是一个标准 容器,则返回一个 C::const_iterator 对象。

range-begin-end.svg

内容

[编辑] 参数

c - 具有 end 成员函数的容器或视图
array - 任意类型的数组

[编辑] 返回值

1,2) c.end()
3) array + N
4) c.end()

[编辑] 异常

4)
noexcept 规范:  
noexcept(noexcept(std::end(c)))

[编辑] 重载

end 的自定义重载可以为没有公开合适的 end() 成员函数但可以迭代的类和枚举提供。以下重载已由标准库提供

专门化 std::end
(函数模板) [编辑]
专门化 std::end
(函数模板) [编辑]
基于范围的 for 循环支持
(函数) [编辑]
基于范围的 for 循环支持
(函数) [编辑]

类似于使用 swap(在 可交换 中描述),在通用上下文中 end 函数的典型用法相当于 using std::end; end(arg);,它允许为用户定义类型选择的 ADL 重载和标准库函数模板出现在同一个重载集中。

template<typename Container, typename Function>
void for_each(Container&& cont, Function f)
{
    using std::begin;
    auto it = begin(cont);
    using std::end;
    auto end_it = end(cont);
 
    for (; it != end_it; ++it)
        f(*it);
}

通过 依赖于参数的查找 找到的 end 的重载可以用来定制 std::ranges::endstd::ranges::cend 和其他自定义指针对象的的行为,这取决于 std::ranges::end

(自 C++20 起)

[编辑] 备注

非数组重载完全反映了 C::end() 的行为。如果成员函数没有合理的实现,它们的效果可能会令人惊讶。

std::cend 用于统一成员和非成员范围访问。另请参见 LWG 问题 2128

如果 C 是一个浅层常量视图,std::cend 可能会返回一个可变迭代器。对于某些用户来说,这种行为是意料之外的。另请参见 P2276P2278

[编辑] 例子

#include <algorithm>
#include <iostream>
#include <vector>
 
int main()
{
    std::vector<int> v = {3, 1, 4};
    if (std::find(std::begin(v), std::end(v), 5) != std::end(v))
        std::cout << "Found a 5 in vector v!\n";
 
    int w[] = {5, 10, 15};
    if (std::find(std::begin(w), std::end(w), 5) != std::end(w))
        std::cout << "Found a 5 in array w!\n";
}

输出

Found a 5 in array w!

[编辑] 另请参见

(C++11)(C++14)
返回指向容器或数组开头的迭代器
(函数模板) [编辑]
返回指示范围结束的哨兵
(定制点对象)[编辑]
返回指示只读范围结束的哨兵
(定制点对象)[编辑]