Namespaces
Variants
Views
Actions

std::ranges::adjacent_view<V,N>::adjacent_view

From cppreference.com
 
 
Ranges library
Range access
Range conversions
(C++23)
Range primitives



Dangling iterator handling
Range concepts
Views

Factories




Adaptors
Range generators
Range adaptor objects
Range adaptor closure objects
Helper items
 
 
adjacent_view() requires std::default_initializable<V> = default;
(1) (since C++23)
constexpr explicit adjacent_view( V base );
(2) (since C++23)

Constructs an adjacent_view.

1) Default constructor. Value-initializes the underlying view.
2) Initializes the underlying view base_ with std::move(base).

[edit] Parameters

base - the underlying view

[edit] Example

A link to test: Compiler Explorer/g++-13

#include <tuple>
#include <ranges>
#include <string>
#include <iostream>
 
template<class... Ts>
void print(std::tuple<Ts...> const& tuple)
{
    std::apply([&](auto&& arg, auto&&... args) {
        std::cout << arg;
        ((std::cout << args), ...);
    }, tuple);
    std::cout << '\n';
}
 
int main()
{
    const std::string v {"ABCDEF"};
    constexpr int window_size{4};
 
    std::cout
        << "window size = " << window_size << '\n'
        << "v = " << v << '\n';
 
    auto view = std::views::adjacent<window_size>(v); // overload (2)
 
    for (auto const& tuple: view)
    {
        print(tuple);
    }
}

Output:

window size = 4
v = ABCDEF
ABCD
BCDE
CDEF