std:: data
From cppreference.net
|
Определено в заголовочном файле
<array>
|
||
|
Определено в заголовочном файле
<deque>
|
||
|
Определено в заголовочном файле
<flat_map>
|
||
|
Определено в заголовочном файле
<flat_set>
|
||
|
Определено в заголовочном файле
<forward_list>
|
||
|
Определено в заголовочном файле
<inplace_vector>
|
||
|
Определено в заголовочном файле
<iterator>
|
||
|
Определено в заголовочном файле
<list>
|
||
|
Определено в заголовочном файле
<map>
|
||
|
Определено в заголовочном файле
<regex>
|
||
|
Определено в заголовочном файле
<set>
|
||
|
Определено в заголовочном файле
<span>
|
||
|
Определено в заголовочном файле
<string>
|
||
|
Определено в заголовочном файле
<string_view>
|
||
|
Определено в заголовочном файле
<unordered_map>
|
||
|
Определено в заголовочном файле
<unordered_set>
|
||
|
Определено в заголовочном файле
<vector>
|
||
|
template
<
class
C
>
constexpr auto data ( C & c ) - > decltype ( c. data ( ) ) ; |
(1) | (начиная с C++17) |
|
template
<
class
C
>
constexpr auto data ( const C & c ) - > decltype ( c. data ( ) ) ; |
(2) | (начиная с C++17) |
|
template
<
class
T,
std::
size_t
N
>
constexpr T * data ( T ( & array ) [ N ] ) noexcept ; |
(3) | (начиная с C++17) |
|
template
<
class
E
>
constexpr const E * data ( std:: initializer_list < E > il ) noexcept ; |
(4) | (начиная с C++17) |
Возвращает указатель на блок памяти, содержащий элементы диапазона.
1,2)
Возвращает
c.
data
(
)
.
3)
Возвращает
array
.
4)
Возвращает
il.
begin
(
)
.
Содержание |
Параметры
| c | - | контейнер или представление с функцией-членом data ( ) |
| array | - | массив произвольного типа |
| il | - | список инициализации std::initializer_list |
Возвращаемое значение
1,2)
c.
data
(
)
3)
array
4)
il.
begin
(
)
Исключения
1)
Может вызывать исключения, определяемые реализацией.
Примечания
Перегрузка для
std::initializer_list
необходима, поскольку он не имеет функции-члена
data
.
| Макрос тестирования возможностей | Значение | Стандарт | Возможность |
|---|---|---|---|
__cpp_lib_nonmember_container_access
|
201411L
|
(C++17) |
std::size()
,
std::data()
, и
std::empty()
|
Возможная реализация
| Первая версия |
|---|
template<class C> constexpr auto data(C& c) -> decltype(c.data()) { return c.data(); } |
| Вторая версия |
template<class C> constexpr auto data(const C& c) -> decltype(c.data()) { return c.data(); } |
| Третья версия |
template<class T, std::size_t N> constexpr T* data(T (&array)[N]) noexcept { return array; } |
| Четвертая версия |
template<class E> constexpr const E* data(std::initializer_list<E> il) noexcept { return il.begin(); } |
Пример
Запустить этот код
#include <cstring> #include <iostream> #include <string> int main() { std::string s{"Hello world!\n"}; char a[20]; // storage for a C-style string std::strcpy(a, std::data(s)); // [s.data(), s.data() + s.size()] is guaranteed to be an NTBS since C++11 std::cout << a; }
Вывод:
Hello world!
Смотрите также
|
(C++20)
|
получает указатель на начало непрерывного диапазона
(объект точки кастомизации) |
|
(C++20)
|
получает указатель на начало диапазона только для чтения с непрерывным расположением
(объект точки кастомизации) |