std::ranges::view_interface<D>::back
来自 cppreference.com
< cpp | ranges | view interface
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) 令
derived
为static_cast<D&>(*this)。等效于return *ranges::prev(ranges::end(derived));。如果empty()
为true(即开始迭代器与哨兵相等),则行为未定义,即使以相同方式获得的迭代器是可解引用的。2) 与(1) 相同,只是
derived
为static_cast<const D&>(*this)。内容 |
[编辑] 参数
(无)
[编辑] 返回值
视图中的最后一个元素。
[编辑] 注释
在 C++20 中,标准库中没有从std::ranges::view_interface派生的类型提供自己的 back()
成员函数。
但是,以下派生类型无法使用默认实现,因为它们从不满足bidirectional_range
也不满足common_range
- std::ranges::basic_istream_view
- std::ranges::lazy_split_view
- std::ranges::split_view
- std::ranges::take_while_view
继承的 back()
成员函数可用于std::ranges::empty_view,但调用它始终会导致未定义的行为。
[编辑] 示例
本节不完整 原因:没有示例 |
[编辑] 另请参见
(C++14) |
返回指向容器或数组开头的反向迭代器 (函数模板) |
(C++20) |
返回指向范围的反向迭代器 (自定义点对象) |
(C++20) |
返回指向只读范围的反向迭代器 (自定义点对象) |