名稱空間
變體
操作

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

來自 cppreference.com
 
 
範圍庫 (Ranges library)
範圍介面卡 (Range adaptors)
 
 
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_rangecommon_range

繼承的 back() 成員函式對於 std::ranges::empty_view 是可用的,但呼叫它總是導致未定義行為。

[編輯] 示例

[編輯] 參閱

返回指向容器或陣列開頭的反向迭代器
(函式模板) [編輯]
返回指向範圍的反向迭代器
(定製點物件)[編輯]
返回只讀範圍的反向迭代器
(定製點物件)[編輯]