名稱空間
變體
操作

std::ranges::split_view<V,Pattern>::split_view

來自 cppreference.com
< cpp‎ | ranges‎ | split_view
 
 
範圍庫 (Ranges library)
範圍介面卡 (Range adaptors)
 
 
定義於標頭檔案 <ranges>
split_view()

    requires std::default_initializable<V> &&

             std::default_initializable<Pattern> = default;
(1) (C++20 起)
constexpr explicit split_view( V base, Pattern pattern );
(2) (C++20 起)
template< ranges::forward_range R >

    requires std::constructible_from<V, views::all_t<R>> &&
             std::constructible_from<Pattern, ranges::single_view<
                                                  ranges::range_value_t<R>>>

constexpr explicit split_view( R&& r, ranges::range_value_t<R> e );
(3) (C++20 起)

構造一個 split_view

base_ 為底層檢視,pattern_ 為分隔符。

1) 預設建構函式。分別使用它們的預設成員初始化器對 base_pattern_ 進行 值初始化
2)std::move(base) 初始化 base_,用 std::move(pattern) 初始化 pattern_
3)views::all(std::forward<R>(r)) 初始化 base_,用 ranges::single_view{std::move(e)} 初始化 pattern_

目錄

[編輯] 引數

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
(P2711R1)
C++20 多引數建構函式不是顯式的 改為 explicit

[編輯] 另請參閱

構造一個 lazy_split_view
(std::ranges::lazy_split_view<V,Pattern> 的公共成員函式) [編輯]