deduction guides for
std::basic_string_view
From cppreference.net
<
cpp
|
string
|
basic string view
|
Определено в заголовочном файле
<string_view>
|
||
|
template
<
class
It,
class
End
>
basic_string_view ( It, End ) - > basic_string_view < std:: iter_value_t < It >> ; |
(1) | (начиная с C++20) |
|
template
<
class
R
>
basic_string_view ( R && ) - > basic_string_view < ranges:: range_value_t < R >> ; |
(2) | (начиная с C++23) |
Эти руководства по выводу предоставлены для std::basic_string_view .
1)
Данное руководство по выводу позволяет определить тип символа из пары итератор-страж. Эта перегрузка участвует в разрешении перегрузки только если
It
удовлетворяет требованиям
contiguous_iterator
и
End
удовлетворяет требованиям
sized_sentinel_for
для
It
.
2)
Данный направляющий вывод позволяет вывести тип символа из диапазона. Эта перегрузка участвует в разрешении перегрузки только если
R
удовлетворяет
contiguous_range
.
Пример
Запустить этот код
#include <array> #include <iostream> #include <string_view> int main() { std::array a1{'n', 'u', 'c', 'l', 'e', 'o', 'n', 's', ':', '\n'}; std::basic_string_view s1(a1.cbegin(), a1.cend()); // вывод типа: CharT -> char static_assert(std::is_same_v<decltype(s1)::value_type, char>); std::cout << s1; std::array a2{L'p', L'r', L'o', L't', L'o', L'n', L's', L'\n'}; std::basic_string_view s2(a2.cbegin(), a2.cend()); // вывод типа: CharT -> wchar_t static_assert(std::is_same_v<decltype(s2)::value_type, wchar_t>); std::wcout << s2; std::array<long, 9> a3{'n', 'e', 'u', 't', 'r', 'o', 'n', 's', '\n'}; std::basic_string_view s3(a3.cbegin(), a3.cend()); // вывод типа: CharT -> long static_assert(std::is_same_v<decltype(s3)::value_type, long>); for (const auto e : s3) std::cout << static_cast<char>(e); }
Вывод:
nucleons: protons neutrons