Namespaces
Variants

std:: get (std::pair)

From cppreference.net
Utilities library
定義済みヘッダー <utility>
template < std:: size_t I, class T1, class T2 >

typename std:: tuple_element < I, std:: pair < T1,T2 > > :: type &

get ( std:: pair < T1, T2 > & p ) noexcept ;
(1) (C++11以降)
(C++14以降 constexpr)
template < std:: size_t I, class T1, class T2 >

const typename std:: tuple_element < I, std:: pair < T1,T2 > > :: type &

get ( const std:: pair < T1,T2 > & p ) noexcept ;
(2) (C++11以降)
(C++14以降 constexpr)
template < std:: size_t I, class T1, class T2 >

typename std:: tuple_element < I, std:: pair < T1,T2 > > :: type &&

get ( std:: pair < T1,T2 > && p ) noexcept ;
(3) (C++11以降)
(C++14以降constexpr)
template < std:: size_t I, class T1, class T2 >

const typename std:: tuple_element < I, std:: pair < T1,T2 > > :: type &&

get ( const std:: pair < T1,T2 > && p ) noexcept ;
(4) (C++11以降)
(C++14以降 constexpr)
template < class T, class U >
constexpr T & get ( std:: pair < T, U > & p ) noexcept ;
(5) (C++14以降)
template < class T, class U >
constexpr const T & get ( const std:: pair < T, U > & p ) noexcept ;
(6) (C++14以降)
template < class T, class U >
constexpr T && get ( std:: pair < T, U > && p ) noexcept ;
(7) (C++14以降)
template < class T, class U >
constexpr const T && get ( const std:: pair < T, U > && p ) noexcept ;
(8) (C++14以降)
template < class T, class U >
constexpr T & get ( std:: pair < U, T > & p ) noexcept ;
(9) (C++14以降)
template < class T, class U >
constexpr const T & get ( const std:: pair < U, T > & p ) noexcept ;
(10) (C++14以降)
template < class T, class U >
constexpr T && get ( std:: pair < U, T > && p ) noexcept ;
(11) (C++14以降)
template < class T, class U >
constexpr const T && get ( const std:: pair < U, T > && p ) noexcept ;
(12) (C++14以降)

tuple-like インターフェースを使用してペアから要素を抽出します。

1-4) インデックスベースのオーバーロードは、インデックス I 0 でも 1 でもない場合、コンパイルに失敗します。
5-12) 型ベースのオーバーロードは、型 T U が同一の場合、コンパイルに失敗します。

目次

パラメータ

p - 内容を抽出するペア

戻り値

1-4) I == 0 の場合 p. first への参照を返し、 I == 1 の場合 p. second への参照を返す。
5-8) p. first への参照を返す。
9-12) p. second への参照を返します。

#include <iostream>
#include <utility>
int main()
{
    auto p = std::make_pair(1, 3.14);
    std::cout << '(' << std::get<0>(p) << ", " << std::get<1>(p) << ")\n";
    std::cout << '(' << std::get<int>(p) << ", " << std::get<double>(p) << ")\n";
}

出力:

(1, 3.14)
(1, 3.14)
翻訳内容: - "Run this code" → "このコードを実行" - "Output:" → "出力:" HTMLタグ、属性、コードブロック内のテキストはすべて保持されています。C++固有の用語(std::make_pair, std::cout, std::getなど)は翻訳せず、元のまま維持しています。

不具合報告

以下の動作変更の欠陥報告書は、以前に公開されたC++規格に対して遡及的に適用されました。

DR 適用対象 公開時の動作 正しい動作
LWG 2485 C++11 (by index)
C++14 (by type)
const pair&& に対するオーバーロードが存在しない オーバーロードが追加される

関連項目

Structured binding (C++17) 指定された名前を初期化子の部分オブジェクトまたはタプルの要素にバインドする
タプルの指定された要素にアクセスする
(function template)
array の要素にアクセスする
(function template)
インデックスまたは型(型が一意の場合)を指定してvariantの値を読み取り、エラー時には例外をスローする
(function template)
std::ranges::subrange からイテレータまたはセンチネルを取得する
(function template)
std::complex から実部または虚部への参照を取得する
(function template)