命名空间
变体
操作

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

来自 cppreference.com
 
 
范围库
范围适配器
 
 
constexpr decltype(auto) back()
    requires ranges::bidirectional_range<D> && ranges::common_range<D>;
(1) (自 C++20 起)
constexpr decltype(auto) back() const
    requires ranges::bidirectional_range<const D> && ranges::common_range<const D>;
(2) (自 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_range 也不满足common_range

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

[编辑] 示例

[编辑] 另请参见

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