- ranges[meta header]
- std::ranges[meta namespace]
- class template[meta id-type]
- cpp23[meta cpp]
- adjacent,pairwise[meta alias]
namespace std::ranges {
template<forward_range V, size_t N>
requires view<V> && (N > 0)
class adjacent_view : public view_interface<adjacent_view<V, N>> { …… }; // (1)
namespace views {
template<std::size_t N>
inline constexpr /*unspecified*/ adjacent = /*unspecified*/; // (2)
inline constexpr auto pairwise = adjacent<2>; // (3)
}
}
adjacent_viewは各要素とそれに隣接する要素をコンパイル時指定の個数ずつ取り出したtupleを要素とするview。
adjacent_viewの要素を1つ取得するごとに、V の要素を N 個取得する。
N が元となるRangeの要素数より大きい場合、このviewは空である。
- (1):
adjacent_viewのクラス定義
- (2):
adjacent_viewを生成するカスタマイゼーションポイントオブジェクト(変数テンプレート)
- (3):
adjacent<2> の別名
| borrowed |
sized |
output |
input |
forward |
bidirectional |
random_access |
contiguous |
common |
viewable |
view |
|
(1) |
〇 |
〇 |
(1) |
(1) |
(1) |
|
(1) |
○ |
○ |
- (2): 式
views::adjacent<N>(E)の効果は次の通り
#include <ranges>
#include <vector>
#include <print>
int main() {
std::vector v = {1, 2, 3, 4, 5, 6};
std::println("{}", v | std::views::adjacent<0>);
std::println("{}", v | std::views::adjacent<1>);
std::println("{}", v | std::views::adjacent<3>);
std::println("{}", v | std::views::adjacent<6>);
std::println("{}", v | std::views::adjacent<7>);
}
- std::views::adjacent[color ff0000]
[]
[(1), (2), (3), (4), (5), (6)]
[(1, 2, 3), (2, 3, 4), (3, 4, 5), (4, 5, 6)]
[(1, 2, 3, 4, 5, 6)]
[]
- Clang: 19 [mark verified]
- GCC: 13 [mark verified]
- Visual C++: 2022 Update 7 [mark verified]