namespace std::ranges {
template<view V>
requires input_range<V>
class slide_view : public view_interface<slide_view<V>> {…… }; // (1)
namespace views {
inline constexpr /*unspecified*/ slide = /*unspecified*/; // (2)
}
}
概要
slide_view
は各要素とそれに隣接する要素を実行時指定の個数ずつ参照するview
のRange。
指定した個数が元となるRangeの要素数より大きい場合、このview
は空である。
- (1):
slide_view
のクラス定義 - (2):
slide_view
を生成するカスタマイゼーションポイントオブジェクト
Rangeコンセプト
外側Range
borrowed | sized | output | input | forward | bidirectional | random_access | contiguous | common | viewable | view |
---|---|---|---|---|---|---|---|---|---|---|
※ | 〇 | 〇 | ※ | ※ | ※ | ※ | ○ | ○ |
- ※: 元となるRangeに従う
内側Range
borrowed | sized | output | input | forward | bidirectional | random_access | contiguous | common | viewable | view |
---|---|---|---|---|---|---|---|---|---|---|
※ | 〇 | 〇 | ※ | ※ | ※ | ※ | ※ | ○ | ○ |
- ※: 元となるRangeに従う
効果
- (2): 式
views::slide(E, N)
の効果はslide_view(E, N)
と等しい。
事前条件
- (2): n > 0
メンバ関数
名前 | 説明 | 対応バージョン |
---|---|---|
(constructor) |
コンストラクタ | C++23 |
base |
V の参照を取得する |
C++23 |
begin |
先頭を指すイテレータを取得する | C++23 |
end |
番兵を取得する | C++23 |
size |
要素数を取得する | C++23 |
継承しているメンバ関数
名前 | 説明 | 対応バージョン |
---|---|---|
empty |
Rangeが空かどうかを判定する | C++23 |
operator bool |
Rangeが空でないかどうかを判定する | C++23 |
front |
先頭要素への参照を取得する | C++23 |
back |
末尾要素への参照を取得する | C++23 |
cbegin |
定数イテレータを取得する | C++23 |
cend |
定数イテレータ(番兵)を取得する | C++23 |
operator[] |
要素へアクセスする | C++23 |
推論補助
名前 | 説明 | 対応バージョン |
---|---|---|
(deduction_guide) |
クラステンプレートの推論補助 | C++23 |
例
#include <ranges>
#include <vector>
#include <print>
int main() {
std::vector v = {1, 2, 3, 4, 5, 6};
std::println("{}", v | std::views::slide(1));
std::println("{}", v | std::views::slide(3));
std::println("{}", v | std::views::slide(6));
std::println("{}", v | std::views::slide(7));
}
出力
[[1], [2], [3], [4], [5], [6]]
[[1, 2, 3], [2, 3, 4], [3, 4, 5], [4, 5, 6]]
[[1, 2, 3, 4, 5, 6]]
[]
バージョン
言語
- C++23
処理系
- Clang: 17 ✅
- GCC: 13.0 ✅
- Visual C++: 2022 Update 3 ✅
関連項目
adjacent_view
:slide_view
と同じように要素を取得するが、個数をコンパイル時に指定する。内側はRangeではなくtuple
となる