std::ranges:: views:: slide, std::ranges:: slide_view
|
ヘッダーで定義
<ranges>
|
||
|
template
<
ranges::
forward_range
V
>
requires
ranges::
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*/
=
|
(3) | ( 説明専用* ) |
|
template
<
class
V
>
concept
/*slide-caches-last*/
=
|
(4) | ( 説明専用* ) |
|
template
<
class
V
>
concept
/*slide-caches-first*/
=
|
(5) | ( 説明専用* ) |
slide_view
は、
view
と数値
n
を受け取り、その
m
th
要素(「ウィンドウ」)が元のビューの
[
m
,
m + n - 1
]
要素を対象とするビューを生成するレンジアダプタです。
- s - n + 1 ( s >= n の場合)
- 0 (それ以外の場合。この場合、結果のビューは空となる)
n が 0 より大きくない場合、動作は未定義です。
slide_view
は常に
forward_range
をモデルし、また適応された
view
型が対応するコンセプトをモデルする場合、
bidirectional_range
、
random_access_range
または
sized_range
もモデルします。
目次 |
データメンバ
| メンバー | 説明 |
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) |
|
|
(C++26)
|
結果の
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
>>
=
|
(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
(クラステンプレート) (レンジアダプタオブジェクト) |
|
|
(C++23)
|
別の
view
の要素の、サイズ
N
の重複しない連続したチャンクである
view
s
のレンジ
(クラステンプレート) (レンジアダプタオブジェクト) |