std::ranges:: views:: join, std::ranges:: join_view
|
Определено в заголовочном файле
<ranges>
|
||
|
template
<
ranges::
input_range
V
>
requires
ranges::
view
<
V
>
and
|
(1) | (начиная с C++20) |
|
namespace
views
{
inline
constexpr
/* unspecified */
join
=
/* unspecified */
;
|
(2) | (начиная с C++20) |
|
Сигнатура вызова
|
||
|
template
<
ranges::
viewable_range
R
>
requires
/* see below */
|
(начиная с C++20) | |
view
состоящий из последовательности, полученной путем выравнивания представления диапазонов.
join_view
моделирует
input_range
.
join_view
моделирует
forward_range
когда:
- ranges:: range_reference_t < V > является ссылочным типом, и
-
V
и
ranges::
range_reference_t
<
V
>
каждый удовлетворяет концепции
forward_range.
join_view
моделирует
bidirectional_range
когда:
- ranges:: range_reference_t < V > является ссылочным типом,
-
V
моделирует
bidirectional_range, и -
ranges::
range_reference_t
<
V
>
моделирует как
bidirectional_range, так иcommon_range.
join_view
моделирует
common_range
когда:
- ranges:: range_reference_t < V > является ссылочным типом, и
-
V
и
ranges::
range_reference_t
<
V
>
каждый моделирует
forward_rangeи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
состоящее из конкатенации адаптированных представлений
(шаблон класса) (объект точки кастомизации) |