std::ranges::view_interface<D>::front
来自 cppreference.cn
< cpp | ranges | view interface
constexpr decltype(auto) front() requires ranges::forward_range<D>; |
(1) | (自 C++20 起) |
constexpr decltype(auto) front() const requires ranges::forward_range<const D>; |
(2) | (自 C++20 起) |
front()
成员函数的默认实现返回派生类型的视图中的首个元素。元素是按值返回还是按引用返回取决于迭代器类型的 operator*。
1) 令
derived
为 static_cast<D&>(*this)。等价于 return *ranges::begin(derived);。如果 empty()
为 true (即开始迭代器与哨位值相等),即使以相同方式获得的迭代器可解引用,行为也是未定义的。2) 与 (1) 相同,除了
derived
为 static_cast<const D&>(*this)。内容 |
[编辑] 参数
(无)
[编辑] 返回值
视图中的首个元素。
[编辑] 注解
在 C++20 中,标准库中没有从 std::ranges::view_interface 派生的类型提供它们自己的 front()
成员函数。几乎所有这些类型都使用默认实现。
一个值得注意的例外是 std::ranges::basic_istream_view。因为它从不满足 forward_range
,所以该视图不能使用继承的 front()
。
继承的 front()
成员函数可用于 std::ranges::empty_view,但对其的调用总是导致未定义行为。
[编辑] 示例
本节尚不完整 原因:没有示例 |
[编辑] 参见
(C++11)(C++14) |
返回指向容器或数组开头的迭代器 (函数模板) |
(C++20) |
返回指向范围开头的迭代器 (定制点对象) |
(C++20) |
返回指向只读范围开头的迭代器 (定制点对象) |