std::basic_string_view<CharT,Traits>::data
Материал из cppreference.com
<tbody>
</tbody>
constexpr const_pointer data() const noexcept; |
(начиная с C++17) | |
Возвращает указатель на базовый массив символов. Указатель таков, что диапазон [data(); data() + size()) является действительным, а значения в нем соответствуют значениям строкового представления.
Параметры
(отсутствуют)
Возвращаемое значение
Указатель на базовый массив символов.
Сложность
Констатная.
Примечание
В отличие от std::basic_string::data() и строковых литералов, data() может возвращать указатель на буфер, который не заканчивается нулем (\0). Поэтому, как правило, является ошибкой передача data() в подпрограмму, которая принимает только const CharT* и ожидает строку с нулевым символом в конце.
Пример
Запустить этот код
#include <iostream>
#include <cstring>
#include <cwchar>
#include <string>
#include <string_view>
int main()
{
std::wstring_view wcstr_v = L"xyzzy";
std::cout << std::wcslen(wcstr_v.data()) << '\n';
// Хорошо: массив символов завершается нулем
char array[3] = {'B', 'a', 'r'};
std::string_view array_v(array, sizeof array);
// std::cout << std::strlen(array_v.data()) << '\n';
// ОШИБКА: массив символов не заканчивается нулем
std::string str(array_v.data(), array_v.size()); // Хорошо
std::cout << std::strlen(str.data()) << '\n';
// Хорошо: массив символов std::string всегда заканчивается нулем
}
Вывод:
5
3
Смотри также
(C++17) |
предоставляет доступ к первому символу (public функция-элемент) |
(C++17) |
предоставляет доступ к последнему символу (public функция-элемент) |