名稱空間
變體
操作

std::ranges::view_interface

來自 cppreference.com
< cpp‎ | ranges
 
 
範圍庫 (Ranges library)
檢視
view_interface
  

範圍介面卡 (Range adaptors)
 
std::ranges::view_interface
 
定義於標頭檔案 <ranges>
template< class D >

    requires std::is_class_v<D> && std::same_as<D, std::remove_cv_t<D>>

class view_interface;
(C++20 起)

std::ranges::view_interface 是用於定義檢視介面的輔助類模板。

view_interface 通常與 CRTP 一起使用

class my_view : public std::ranges::view_interface<my_view>
{
public:
    auto begin() const { /*...*/ }
    auto end() const { /*...*/ }
    // empty() is provided if begin() returns a forward iterator
    // and end() returns a sentinel for it.
};

目錄

[編輯] 成員函式

返回派生檢視是否為空,僅當它滿足 sized_rangeforward_range 時才提供。
(公有成員函式) [編輯]
(C++23)
返回範圍開頭的常量迭代器
(公有成員函式) [編輯]
(C++23)
返回範圍常量迭代器的哨兵
(公有成員函式) [編輯]
返回派生檢視是否非空,僅當 ranges::empty 適用於它時提供
(公有成員函式) [編輯]
獲取派生檢視資料地址,僅當其迭代器型別滿足 contiguous_iterator 時提供
(公有成員函式) [編輯]
返回派生檢視中的元素數量。如果它滿足 forward_range 並且其哨兵和迭代器型別滿足 sized_sentinel_for,則提供此函式。
(公有成員函式) [編輯]
返回派生檢視中的第一個元素,如果它滿足 forward_range 則提供
(公有成員函式) [編輯]
返回派生檢視中的最後一個元素,僅當它滿足 bidirectional_rangecommon_range 時才提供
(公有成員函式) [編輯]
返回派生檢視中的第 n 個元素,僅當它滿足 random_access_range 時提供
(公有成員函式) [編輯]

[編輯] 示例

#include <iostream>
#include <ranges>
#include <vector>
 
template<class T, class A>
class VectorView : public std::ranges::view_interface<VectorView<T, A>>
{
public:
    VectorView() = default;
 
    VectorView(const std::vector<T, A>& vec) :
        m_begin(vec.cbegin()), m_end(vec.cend())
    {}
 
    auto begin() const { return m_begin; }
 
    auto end() const { return m_end; }
 
private:
    typename std::vector<T, A>::const_iterator m_begin{}, m_end{};
};
 
int main()
{
    std::vector<int> v = {1, 4, 9, 16};
 
    VectorView view_over_v{v};
 
    // We can iterate with begin() and end().
    for (int n : view_over_v)
        std::cout << n << ' ';
    std::cout << '\n';
 
    // We get operator[] for free when inheriting from view_interface
    // since we satisfy the random_access_range concept.
    for (std::ptrdiff_t i = 0; i != view_over_v.size(); ++i)
        std::cout << "v[" << i << "] = " << view_over_v[i] << '\n';
}

輸出

1 4 9 16
v[0] = 1
v[1] = 4
v[2] = 9
v[3] = 16

[編輯] 缺陷報告

下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。

缺陷報告 應用於 釋出時的行為 正確的行為
LWG 3549 C++20 view_interface 要求派生自 view_base
這有時會導致檢視中出現多個 view_base 子物件
繼承已移除

[編輯] 參見

將迭代器-哨兵對組合成view
(類模板) [編輯]