Namespaces
Variants

std:: tuple_element <std::pair>

From cppreference.net
Utilities library
헤더에 정의됨 <utility>
template < std:: size_t I, class T1, class T2 >
struct tuple_element < I, std:: pair < T1, T2 >> ;
(C++11부터)

std:: tuple_element 의 부분 특수화는 튜플과 유사한 구문을 사용하여 pair의 요소 타입들에 대한 컴파일 타임 접근을 제공합니다. I >= 2 인 경우 프로그램은 형식에 맞지 않습니다.

목차

멤버 타입

멤버 타입 정의
type T1 만약 I == 0
T2 만약 I == 1

가능한 구현

template<std::size_t I, typename T>
struct tuple_element;
template<std::size_t I, typename T1, typename T2>
struct tuple_element<I, std::pair<T1, T2>>
{
    static_assert(I < 2, "std::pair has only 2 elements!");
};
template<typename T1, typename T2>
struct tuple_element<0, std::pair<T1, T2>>
{
    using type = T1;
};
template<typename T1, typename T2>
struct tuple_element<1, std::pair<T1, T2>>
{
    using type = T2;
};

예제

#include <iostream>
#include <string>
#include <tuple>
namespace detail
{
    template<std::size_t>
    struct index_tag { constexpr explicit index_tag() = default; };
    template<class T, class U>
    constexpr T get_val_dispatch(std::pair<T, U> const& pair, index_tag<0>)
    {
        return pair.first;
    }
    template<class T, class U>
    constexpr U get_val_dispatch(std::pair<T, U> const& pair, index_tag<1>)
    {
        return pair.second;
    }
} // namespace detail
template<std::size_t N, class T, class U>
auto constexpr get_val(std::pair<T, U> const& pair)
    -> typename std::tuple_element<N, std::pair<T, U>>::type
{
    return detail::get_val_dispatch(pair, detail::index_tag<N>{});
}
int main()
{
    auto var = std::make_pair(1, std::string{"one"});
    std::cout << get_val<0>(var) << " = " << get_val<1>(var);
}

출력:

1 = one

결함 보고서

다음의 동작 변경 결함 보고서들은 이전에 발표된 C++ 표준에 소급 적용되었습니다.

DR 적용 대상 게시된 동작 올바른 동작
LWG 2974 C++11 범위를 벗어난 인덱스가 정의되지 않은 기본 템플릿을 참조함 형식 오류(하드 에러)로 지정됨

참고 항목

Structured binding (C++17) 지정된 이름들을 초기화자의 부분 객체나 튜플 요소에 바인딩합니다
지정된 요소의 타입을 얻습니다
(클래스 템플릿 특수화)
array 의 요소 타입을 얻습니다
(클래스 템플릿 특수화)
std::ranges::subrange 의 반복자나 센티널 타입을 얻습니다
(클래스 템플릿 특수화)
pair 의 크기를 얻습니다
(클래스 템플릿 특수화)