Namespaces
Variants

std:: data

From cppreference.net
Iterator library
Iterator concepts
Iterator primitives
Algorithm concepts and utilities
Indirect callable concepts
Common algorithm requirements
(C++20)
(C++20)
(C++20)
Utilities
(C++20)
Iterator adaptors
Range access
(C++11) (C++14)
(C++14) (C++14)
(C++11) (C++14)
(C++14) (C++14)
(C++17) (C++20)
(C++17)
data
(C++17)
Определено в заголовочном файле <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!

Смотрите также

получает указатель на начало непрерывного диапазона
(объект точки кастомизации)
получает указатель на начало диапазона только для чтения с непрерывным расположением
(объект точки кастомизации)