std::basic_string_view<CharT,Traits>::data
De cppreference.com
< cpp | string | basic string view
constexpr const_pointer data() const noexcept; |
(desde C++17) | |
Devuelve un puntero al array de caracteres subyacente. El puntero es tal que el rango [data(); data() + size()) es válido y los valores en él corresponden a los valores de la vista.
Contenido |
[editar] Parámetros
(ninguno)
[editar] Valor de retorno
Un puntero al array de caracteres subyacente.
[editar] Complejidad
Constante.
[editar] Notas
A diferencia de std::basic_string::data() y los literales de cadena, data()
puede devolver un puntero a un búfer que no está terminado en nulo. Por lo tanto, típicamente es un error pasar data()
a una rutina que toma solamente un puntero const CharT*
y que espera una cadena terminada en nulo.
[editar] Ejemplo
Ejecuta este código
#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'; // de acuerdo: el array de caracteres subyacente está terminado en nulo char array[3] = {'B', 'a', 'r'}; std::string_view array_v(array, sizeof array); // std::cout << std::strlen(array_v.data()) << '\n'; // ERROR: el array de caracteres subyacente no está terminado en nulo std::string str(array_v.data(), array_v.size()); // de acuerdo std::cout << std::strlen(str.data()) << '\n'; // de acuerdo: el array de caracteres subyacente de un std::string // siempre está terminado en nulo }
Salida:
5 3
[editar] Véase también
Accede al primer carácter. (función miembro pública) | |
Accede al último carácter. (función miembro pública) |