std::basic_string_view<CharT,Traits>::data
De cppreference.com
<tbody>
</tbody>
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.
Parámetros
(ninguno)
Valor de retorno
Un puntero al array de caracteres subyacente.
Complejidad
Constante.
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.
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
Véase también
| Accede al primer carácter. (función miembro pública) | |
| Accede al último carácter. (función miembro pública) |