Namespaces
Variants

std::ranges:: views:: join, std::ranges:: join_view

From cppreference.net
Ranges library
Range adaptors
Определено в заголовочном файле <ranges>
template < ranges:: input_range V >

requires ranges:: view < V > and
ranges:: input_range < ranges:: range_reference_t < V >>
class join_view

: public ranges:: view_interface < join_view < V >>
(1) (начиная с C++20)
namespace views {

inline constexpr /* unspecified */ join = /* unspecified */ ;

}
(2) (начиная с C++20)
Сигнатура вызова
template < ranges:: viewable_range R >

requires /* see below */

constexpr ranges:: view auto join ( R && r ) ;
(начиная с C++20)
1) Адаптер диапазона, представляющий view состоящий из последовательности, полученной путем выравнивания представления диапазонов.
2) RangeAdaptorObject (а также RangeAdaptorClosureObject ). Выражение views :: join ( e ) является эквивалентным по выражению к join_view < views:: all_t < decltype ( ( e ) ) >> { e } для любых подходящих подвыражений e .

join_view моделирует input_range .

join_view моделирует forward_range когда:

join_view моделирует bidirectional_range когда:

join_view моделирует common_range когда:

Содержание

Функции-члены

конструирует join_view
(публичная функция-член)
возвращает копию базового (адаптированного) представления
(публичная функция-член)
возвращает итератор на начало
(публичная функция-член)
возвращает итератор или страж на конец
(публичная функция-член)
Наследуется от std::ranges::view_interface
возвращает, является ли производное представление пустым, предоставляется только если оно удовлетворяет sized_range или forward_range
(публичная функция-член std::ranges::view_interface<D> )
(C++23)
возвращает константный итератор на начало диапазона
(публичная функция-член std::ranges::view_interface<D> )
(C++23)
возвращает страж для константного итератора диапазона
(публичная функция-член std::ranges::view_interface<D> )
возвращает, является ли производное представление непустым, предоставляется только если ranges::empty применимо к нему
(публичная функция-член std::ranges::view_interface<D> )
возвращает первый элемент в производном представлении, предоставляется если оно удовлетворяет forward_range
(публичная функция-член std::ranges::view_interface<D> )
возвращает последний элемент в производном представлении, предоставляется только если оно удовлетворяет bidirectional_range и common_range
(публичная функция-член std::ranges::view_interface<D> )

Руководства по выводу

Вложенные классы

тип итератора
( только для демонстрации (шаблон класса-члена*) )
тип сторожа
( только для демонстрации (шаблон класса-члена*) )

Примечания

До принятия P2328R1 тип внутреннего диапазона ( ranges:: range_reference_t < V > ) не мог быть типом контейнера (но мог быть ссылкой на контейнер). Например, не допускалось соединение transform_view из std::string prvalue.

struct Person { int age; std::string name; };
auto f(std::vector<Person>& v) {
//  return v | std::views::transform([](auto& p){ return p.name; })
//           | std::views::join; // ошибка до P2328R1
    return v | std::views::transform([](auto& p) -> std::string& { return p.name; })
             | std::views::join; // OK
}

Пример

#include <iostream>
#include <ranges>
#include <string_view>
#include <vector>
int main()
{
    using namespace std::literals;
    const auto bits = {"https:"sv, "//"sv, "cppreference"sv, "."sv, "com"sv};
    for (char const c : bits | std::views::join)
        std::cout << c;
    std::cout << '\n';
    const std::vector<std::vector<int>> v{{1, 2}, {3, 4, 5}, {6}, {7, 8, 9}};
    auto jv = std::ranges::join_view(v);
    for (int const e : jv)
        std::cout << e << ' ';
    std::cout << '\n';
}

Вывод:

https://cppreference.net
1 2 3 4 5 6 7 8 9

Отчеты о дефектах

Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.

DR Применяется к Поведение в опубликованной версии Корректное поведение
LWG 3474 C++20 views :: join ( e ) возвращал копию e когда e является join_view возвращает вложенный join_view
P2328R1 C++20 не-view range prvalues не могли быть объединены с помощью join_view сделано объединяемым

Смотрите также

представление, view состоящее из последовательности, полученной путём сглаживания представления диапазонов, с разделителем между элементами
(шаблон класса) (объект адаптера диапазона)
представление, view состоящее из конкатенации адаптированных представлений
(шаблон класса) (объект точки кастомизации)