std::basic_string_view<CharT,Traits>:: data
|
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.
Contenidos |
Parámetros
(ninguno)
Valor de retorno
Un puntero al arreglo de caracteres subyacente.
Complejidad
Constante.
Notas
A diferencia de
std::basic_string::data()
y los literales de cadena,
std::basic_string_view::data()
devuelve un puntero a un búfer que no está necesariamente terminado en nulo, por ejemplo una vista de subcadena (como desde
remove_suffix
). Por lo tanto, normalmente es un error pasar
data()
a una rutina que toma solo un
const
CharT
*
y espera una cadena terminada en nulo.
Ejemplo
#include <cstring> #include <cwchar> #include <iostream> #include <string> #include <string_view> int main() { std::wstring_view wcstr_v = L"xyzzy"; std::cout << std::wcslen(wcstr_v.data()) << '\n'; // OK: 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()); // OK std::cout << std::strlen(str.data()) << '\n'; // OK: 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) |
|
|
devuelve un puntero al primer carácter de una cadena
(función miembro pública de
std::basic_string<CharT,Traits,Allocator>
)
|