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) 구현에서 정의된 예외를 throw할 수 있습니다.

참고 사항

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]; // C-style 문자열을 위한 저장 공간
    std::strcpy(a, std::data(s));
//  [s.data(), s.data() + s.size()]는 C++11부터 NTBS임이 보장됨
    std::cout << a;
}

출력:

Hello world!

참고 항목

연속 범위의 시작 부분에 대한 포인터를 획득
(customization point object)
읽기 전용 연속 범위의 시작 부분에 대한 포인터를 획득
(customization point object)