命名空间
变体
视图
操作

std::ranges::view_interface<D>::back

来自 cppreference.cn
 
 
范围库
范围适配器
 
 
constexpr decltype(auto) back()
    requires ranges::bidirectional_range<D> && ranges::common_range<D>;
(1) (since C++20)
constexpr decltype(auto) back() const
    requires ranges::bidirectional_range<const D> && ranges::common_range<const D>;
(2) (since C++20)

back() 成员函数的默认实现返回派生类型的视图中的最后一个元素。元素是通过值还是通过引用返回取决于迭代器类型的 operator*

1)derivedstatic_cast<D&>(*this)。等价于 return *ranges::prev(ranges::end(derived));。如果 empty()true (即,起始迭代器与哨位比较相等),即使以相同方式获得的迭代器是可解引用的,行为也是未定义的。
2)(1) 相同,除了 derivedstatic_cast<const D&>(*this)

内容

[编辑] 参数

(无)

[编辑] 返回值

视图中的最后一个元素。

[编辑] 注意

在 C++20 中,标准库中没有从 std::ranges::view_interface 派生的类型提供它们自己的 back() 成员函数。

但是,以下派生类型不能使用默认实现,因为它们永远不满足 bidirectional_rangecommon_range

继承的 back() 成员函数可用于 std::ranges::empty_view,但对其的调用总是会导致未定义的行为。

[编辑] 示例

[编辑] 参见

返回指向容器或数组开头的反向迭代器
(函数模板) [编辑]
返回指向范围的反向迭代器
(定制点对象)[编辑]
返回指向只读范围的反向迭代器
(定制点对象)[编辑]