cpp/ranges/split view/split view — cppreference.com
Материал из cppreference.com
Шаблон:cpp/ranges/split view/title
<tbody> </tbody>
| Определено в заголовочном файле |
||
|
|
(1) | (начиная с C++20) |
|
|
(2) | (начиная с C++20) |
|
|
(3) | (начиная с C++20) |
Создает split_view.
Пусть base_ - базовое представление, а pattern_ разделитель.
1) Конструктор по умолчанию. Value-initializes base_ и pattern_ с их конструкторами по умолчанию соответственно.
2) Инициализирует base_ с std::move(base) и pattern_ с std::move(pattern).
3) Инициализирует base_ с views::all(std::forward<R>(r)) и pattern_ с ranges::single_view{std::move(e)}.
Параметры
| base | — | представление (которое будет разбиваться) |
| pattern | — | представление которое будет использовано как разделитель |
| e | — | элемент который будет использован как разделитель |
Пример
#include <algorithm> #include <array> #include <cctype> #include <iostream> #include <iterator> #include <ranges> #include <string_view> #include <vector> int main() { { auto view = std::views::iota(1, 20) | std::views::transform([](int x) { return x % 5; }); auto splitts = std::views::split(view, 0); // (2) for (const auto& split : splitts) { std::cout << "{ "; std::ranges::copy(split, std::ostream_iterator<int>(std::cout, " ")); std::cout << "} "; } } std::cout << '\n'; { const std::vector nums{1, -1, -1, 2, 3, -1, -1, 4, 5, 6}; const std::array delim{-1, -1}; auto splitter = std::views::split(nums, delim); // (3) for (const auto& split : splitter) { std::cout << "{ "; std::ranges::copy(split, std::ostream_iterator<int>(std::cout, " ")); std::cout << "} "; } } std::cout << '\n'; { constexpr std::string_view JupiterMoons { "Callisto, Europa, Ganymede, Io, and 91 more" }; constexpr std::string_view delim{", "}; std::ranges::split_view moons_extractor{JupiterMoons, delim}; // (3) auto is_moon = std::views::filter([](auto str) { return std::isupper(str[0]); }); std::cout << "Some moons of Jupiter: "; for (const auto moon : moons_extractor | is_moon) std::cout << std::string_view(moon) << ' '; } std::cout << '\n'; }
Вывод:
{ 1 2 3 4 } { 1 2 3 4 } { 1 2 3 4 } { 1 2 3 4 }
{ 1 } { 2 3 } { 4 5 6 }
Some moons of Jupiter: Callisto Europa Ganymede Io
Отчеты об ошибках
Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:
| Номер | Применён | Поведение в стандарте | Корректное поведение |
|---|---|---|---|
| LWG 3714 | C++20 | конструктор с несколькими аргументами не был explicit | сделан explicit |