Namespaces
Variants

std::ranges:: views:: slide, std::ranges:: slide_view

From cppreference.net
Ranges library
Range adaptors
ヘッダーで定義 <ranges>
template < ranges:: forward_range V >

requires ranges:: view < V >
class slide_view

: public ranges:: view_interface < slide_view < V >>
(1) (C++23以降)
namespace views {

inline constexpr /* 未規定 */ slide = /* 未規定 */ ;

}
(2) (C++23以降)
呼び出しシグネチャ
template < ranges:: viewable_range R >
constexpr ranges:: view auto slide ( R && r, ranges:: range_difference_t < R > n ) ;
(C++23以降)
template < class DifferenceType >
constexpr /* レンジアダプタオブジェクト */ slide ( DifferenceType && n ) ;
(C++23以降)
ヘルパーコンセプト
template < class V >

concept /*slide-caches-nothing*/ =

ranges:: random_access_range < V > && ranges:: sized_range < V > ;
(3) ( 説明専用* )
template < class V >

concept /*slide-caches-last*/ =
! /*slide-caches-nothing*/ < V > &&

ranges:: bidirectional_range < V > && ranges:: common_range < V > ;
(4) ( 説明専用* )
template < class V >

concept /*slide-caches-first*/ =

! /*slide-caches-nothing*/ < V > && ! /*slide-caches-last*/ < V > ;
(5) ( 説明専用* )
1) slide_view は、 view と数値 n を受け取り、その m th 要素(「ウィンドウ」)が元のビューの [ m , m + n - 1 ] 要素を対象とするビューを生成するレンジアダプタです。
元のビューのサイズを s とする。このとき、生成されるビューのサイズは以下の通り:
  • s - n + 1 s >= n の場合)
  • 0 (それ以外の場合。この場合、結果のビューは空となる)
2) 名前 views :: slide RangeAdaptorObject を表す。部分式 e および n が与えられたとき、式 views :: slide ( e, n ) 式等価 である slide_view ( e, n ) に。

n 0 より大きくない場合、動作は未定義です。

slide_view は常に forward_range をモデルし、また適応された view 型が対応するコンセプトをモデルする場合、 bidirectional_range random_access_range または sized_range もモデルします。

目次

翻訳の説明: - 「Contents」→「目次」に翻訳 - C++専門用語(Data members, Member functions, Deduction guides, Nested classes, Helper templates, Notes, Example, References, See also)は原文のまま保持 - HTMLタグ、属性、 タグ内の`std::ranges::view_interface`は一切翻訳せず保持 - 番号や構造は完全に維持

データメンバ

メンバー 説明
V base_ 基となるビュー
( 説明専用メンバーオブジェクト* )
ranges:: range_difference_t < V > n_ 「ウィンドウ」サイズ
( 説明専用メンバーオブジェクト* )
non-propagating-cache < ranges:: iterator_t < V >> cached_begin_
(存在するのは V slide-caches-first をモデル化する場合のみ)
begin() の結果をキャッシュするオブジェクト
( 説明専用メンバーオブジェクト* )
non-propagating-cache < ranges:: iterator_t < V >> cached_end_
(存在するのは V slide-caches-last をモデル化する場合のみ)
end() の結果をキャッシュするオブジェクト
( 説明専用メンバーオブジェクト* )

メンバー関数

slide_view を構築する
(public member function)
先頭を指すイテレータを返す
(public member function)
終端を指すイテレータまたはセンチネルを返す
(public member function)
要素数を返す(基となる(適応された)範囲が sized_range を満たす場合にのみ提供)
(public member function)
結果の approximately_sized_range の近似サイズを返す
(public member function)
std::ranges::view_interface から継承
派生ビューが空かどうかを返す( sized_range または forward_range を満たす場合にのみ提供)
( std::ranges::view_interface<D> のpublic member function)
(C++23)
範囲の先頭を指す定数イテレータを返す
( std::ranges::view_interface<D> のpublic member function)
(C++23)
範囲の定数イテレータのセンチネルを返す
( std::ranges::view_interface<D> のpublic member function)
派生ビューが空でないかどうかを返す( ranges::empty が適用可能な場合にのみ提供)
( std::ranges::view_interface<D> のpublic member function)
派生ビューの最初の要素を返す( forward_range を満たす場合に提供)
( std::ranges::view_interface<D> のpublic member function)
派生ビューの最後の要素を返す( bidirectional_range かつ common_range を満たす場合にのみ提供)
( std::ranges::view_interface<D> のpublic member function)
派生ビューの n th 番目の要素を返す( random_access_range を満たす場合にのみ提供)
( std::ranges::view_interface<D> のpublic member function)

推論ガイド

ネストされたクラス

(C++23)
イテレータ型
( 説明専用メンバクラステンプレート* )
(C++23)
slide_view common_range でない場合に使用されるセンチネル型
( 説明専用メンバクラステンプレート* )

ヘルパーテンプレート

template < class V >

constexpr bool ranges:: enable_borrowed_range < slide_view < V >> =

ranges:: enable_borrowed_range < V > ;
(C++23以降)

この ranges::enable_borrowed_range の特殊化は、基盤となるビューが borrowed_range を満たす場合に、 slide_view がそれを満たすようにする。

注記

ranges::adjacent_view ranges::slide_view には類似点があります:

  • 両方ともサイズ N の「スライディングウィンドウ」を作成します。
  • 両方とも同じサイズ S - N + 1 を持ちます。ここで S は適応された view のサイズであり、 S >= N > 0 という条件を満たします。

以下の表は、これらのアダプタの違いを示しています:

ビューアダプタ value_type ウィンドウサイズ N
ranges:: adjacent_view std::tuple テンプレートパラメータ
ranges :: slide_view ranges:: range 実行時引数
機能テスト マクロ 標準 機能
__cpp_lib_ranges_slide 202202L (C++23) std::ranges::slide_view

#include <algorithm>
#include <initializer_list>
#include <iostream>
#include <ranges>
auto print_subrange = [](std::ranges::viewable_range auto&& r)
{
    std::cout << '[';
    for (char space[]{0,0}; auto elem : r)
        std::cout << space << elem, *space = ' ';
    std::cout << "] ";
};
int main()
{
    const auto v = {1, 2, 3, 4, 5, 6};
    std::cout << "All sliding windows of width:\n";
    for (const unsigned width : std::views::iota(1U, 1U + v.size()))
    {
        auto const windows = v | std::views::slide(width);
        std::cout << "W = " << width << ": ";
        std::ranges::for_each(windows, print_subrange);
        std::cout << '\n';
    }
}

出力:

All sliding windows of width W:
W = 1: [1] [2] [3] [4] [5] [6] 
W = 2: [1 2] [2 3] [3 4] [4 5] [5 6] 
W = 3: [1 2 3] [2 3 4] [3 4 5] [4 5 6] 
W = 4: [1 2 3 4] [2 3 4 5] [3 4 5 6] 
W = 5: [1 2 3 4 5] [2 3 4 5 6] 
W = 6: [1 2 3 4 5 6]

参考文献

  • C++23規格 (ISO/IEC 14882:2024):
  • 26.7.29 スライドビュー [range.slide]

関連項目

適応されたビューの隣接する要素への参照のタプルから構成される view
(クラステンプレート) (レンジアダプタオブジェクト)
別の view の要素の、サイズ N の重複しない連続したチャンクである view s のレンジ
(クラステンプレート) (レンジアダプタオブジェクト)