Namespaces
Variants

deduction guides for std::ranges::lazy_split_view

From cppreference.net
Ranges library
Range adaptors
template < class R, class P >

lazy_split_view ( R && , P && )

- > lazy_split_view < views:: all_t < R > , views:: all_t < P >> ;
(1) (seit C++20)
template < ranges:: input_range R >

lazy_split_view ( R && , ranges:: range_value_t < R > )
- > lazy_split_view < views:: all_t < R > ,

ranges:: single_view < ranges:: range_value_t < R >>> ;
(2) (seit C++20)

Diese Deduction Guides werden für lazy_split_view bereitgestellt, um die Ableitung aus einem Range und einem Delimiter zu ermöglichen.

1) Das Trennzeichen ist ein Bereich von Elementen.
2) Das Trennzeichen ist ein einzelnes Element.

Beispiel

#include <ranges>
#include <string_view>
#include <type_traits>
using std::operator""sv;
int main()
{
    std::ranges::lazy_split_view w1{"a::b::c"sv, "::"sv};
    // Typ von w1 ist lazy_split_view<string_view, string_view>:
    static_assert(std::is_same_v<
        decltype(w1),
        std::ranges::lazy_split_view<
            std::basic_string_view<char, std::char_traits<char>>,
            std::basic_string_view<char, std::char_traits<char>>>>);
    std::ranges::lazy_split_view w2{"x,y,z"sv, ','};
    // Typ von w2 ist lazy_split_view<string_view, single_view<char>>:
    static_assert(std::is_same_v<
        decltype(w2),
        std::ranges::lazy_split_view<
            std::basic_string_view<char, std::char_traits<char>>,
            std::ranges::single_view<char>>>);
}