std::basic_string<CharT,Traits,Allocator>::operator basic_string_view
Материал из cppreference.com
< cpp | string | basic string
operator std::basic_string_view<CharT, Traits>()constnoexcept; | (начиная с C++17) (до C++20) | |
constexpr operator std::basic_string_view<CharT, Traits>()constnoexcept; | (начиная с 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());// OKstd::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> ) |