std::basic_string<CharT,Traits,Allocator>::operator basic_string_view
Материал из cppreference.com
< cpp | string | basic string
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> )
|