Namespaces
Variants

std::ranges:: end

From cppreference.net
Ranges library
Range adaptors
定义于头文件 <ranges>
定义于头文件 <iterator>
inline namespace /* 未指定 */ {

inline constexpr /* 未指定 */ end = /* 未指定 */ ;

}
(C++20 起)
(定制点对象)
调用签名
template < class T >

requires /* 见下文 */

constexpr std:: sentinel_for < ranges:: iterator_t < T >> auto end ( T && t ) ;
(C++20 起)

返回表示范围结束的哨兵值。

range-begin-end.svg

如果实参是左值或 ranges:: enable_borrowed_range < std:: remove_cv_t < T >> true ,则对 ranges::end 的调用 表达式等价 于:

  1. t + std:: extent_v < T > t 具有已知边界的数组类型。
  2. 否则, decay-copy ( t. end ( ) ) (C++23 前) auto ( t. end ( ) ) (C++23 起) ,若该表达式合法且其类型满足 std:: sentinel_for < ranges:: iterator_t < T >>
  3. 否则, decay-copy ( end ( t ) ) (C++23 前) auto ( end ( t ) ) (C++23 起) ,若 T 是类或枚举类型,该表达式合法且其转换后的类型满足 std:: sentinel_for < ranges:: iterator_t < T >> ,其中 end 的含义通过仅执行 实参依赖查找 来确定。

在所有其他情况下,对 ranges::end 的调用都是非良构的,当该调用出现在模板实例化的直接上下文时,可能导致 替换失败

目录

定制点对象

名称 ranges::end 表示一个 定制点对象 ,它是一个常量 函数对象 ,具有 字面量 semiregular 类类型。详细信息请参阅 定制点对象

注释

若实参为右值(即 T 为对象类型)且 ranges:: enable_borrowed_range < std:: remove_cv_t < T >> false ,或其为未知边界数组类型,则对 ranges::end 的调用将导致非良构,同时引发替换失败。

ranges :: end ( std:: forward < T > ( t ) ) 有效,则 decltype ( ranges :: end ( std:: forward < T > ( t ) ) ) decltype ( ranges:: begin ( std:: forward < T > ( t ) ) ) 在所有情况下均满足 std::sentinel_for 概念,同时 T 满足 std::ranges::range 概念。

C++20 标准要求:若底层 end 函数调用返回纯右值,则返回值应从物化的临时对象移动构造。但所有实现都直接返回该纯右值。这一要求已通过后 C++20 提案 P0849R8 修正以符合现有实现。

示例

#include <algorithm>
#include <iostream>
#include <ranges>
#include <vector>
int main()
{
    std::vector<int> vec{3, 1, 4};
    if (std::ranges::find(vec, 5) != std::ranges::end(vec))
        std::cout << "在向量 vec 中找到了 5!\n";
    int arr[]{5, 10, 15};
    if (std::ranges::find(arr, 5) != std::ranges::end(arr))
        std::cout << "在数组 arr 中找到了 5!\n";
}

输出:

在数组 arr 中找到了 5!

缺陷报告

以下行为变更缺陷报告被追溯应用于先前发布的C++标准。

缺陷报告 应用于 发布时行为 正确行为
P2602R2 C++20 存在机制来禁止通过 ADL 找到的某些非成员 end 移除此类机制

参见

返回指向只读范围末尾的哨兵
(定制点对象)
返回指向范围起始位置的迭代器
(定制点对象)
(C++11) (C++14)
返回指向容器或数组末尾的迭代器
(函数模板)