std::basic_string<CharT,Traits,Allocator>::operator basic_string_view
Материал из cppreference.com
<tbody>
</tbody>
<tbody class="t-dcl-rev ">
</tbody><tbody>
</tbody>
operator std::basic_string_view<CharT, Traits>() const noexcept; |
(начиная с C++17) (до C++20) |
|
constexpr operator std::basic_string_view<CharT, Traits>() const noexcept; |
(начиная с C++20) | |
Возвращает std::basic_string_view, созданный как будто с помощью std::basic_string_view<CharT, Traits>(data(), size()).
Параметры
(нет)
Возвращаемое значение
Строковое представление, представляющее всё содержимое строки.
Примечание
Ответственность за то, чтобы полученное представление строки не пережило строку, лежит на программисте.
std::string get_string();
int f(std::string_view sv);
int x = f(get_string()); // OK
std::string_view sv = get_string(); // Плохо: содержит висячий указатель
Пример
Запустить этот код
#include <iostream>
#include <string>
#include <string_view>
void show_wstring_size(std::wstring_view wcstr_v)
{
std::cout << wcstr_v.size() << " кодовые точки\n";
}
int main()
{
std::string cppstr = "ラーメン"; // узкая строка
std::wstring wcstr = L"ラーメン"; // широкая строка
// Неявное преобразование из string в string_view
// через std::string::operator string_view:
std::string_view cppstr_v = cppstr;
std::cout << cppstr_v << '\n'
<< cppstr_v.size() << " кодовых точек\n";
// Неявное преобразование из wstring в wstring_view
// через std::wstring::operator wstring_view:
show_wstring_size(wcstr);
}
Вывод:
ラーメン
12 кодовых точек
4 кодовые точки
Смотрите также
(C++17) |
конструирует basic_string_view (public функция-элемент std::basic_string_view<CharT,Traits>)
|