std::end, std::cend
来自 cppreference.com
在头文件 <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(/* 见下文 */) |
(4) | (自 C++14 起) |
返回指向给定范围末尾(即最后一个元素之后的元素)的迭代器。
1,2) 返回 c.end(),它通常是代表 c 的序列末尾后的一个迭代器。
3) 返回指向 array 末尾的指针。
4) 返回 std::end(c),其中 c 始终被视为 const 限定。
内容 |
[编辑] 参数
c | - | 具有 end 成员函数的容器或视图 |
array | - | 任意类型的数组 |
[编辑] 返回值
1,2) c.end()
3) array + N
4) c.end()
[编辑] 异常
4)
noexcept 规范:
noexcept(noexcept(std::end(c)))
[编辑] 重载
end
的自定义重载可以为没有公开合适的 end()
成员函数但可以迭代的类和枚举提供。以下重载已由标准库提供
专门化 std::end (函数模板) | |
(C++11) |
专门化 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); }
通过 依赖于参数的查找 找到的 |
(自 C++20 起) |
[编辑] 备注
非数组重载完全反映了 C::end() 的行为。如果成员函数没有合理的实现,它们的效果可能会令人惊讶。
std::cend
用于统一成员和非成员范围访问。另请参见 LWG 问题 2128。
如果 C
是一个浅层常量视图,std::cend
可能会返回一个可变迭代器。对于某些用户来说,这种行为是意料之外的。另请参见 P2276 和 P2278。
[编辑] 例子
运行这段代码
#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) |
返回指向容器或数组开头的迭代器 (函数模板) |
(C++20) |
返回指示范围结束的哨兵 (定制点对象) |
(C++20) |
返回指示只读范围结束的哨兵 (定制点对象) |