Namespaces
Variants

std:: make_pair

From cppreference.net
Utilities library
ヘッダーで定義 <utility>
template < class T1, class T2 >
std:: pair < T1, T2 > make_pair ( T1 x, T2 y ) ;
(C++11まで)
template < class T1, class T2 >
std:: pair < /*V1*/ , /*V2*/ > make_pair ( T1 && x, T2 && y ) ;
(C++11から)
(constexprはC++14から)
(C++20まで)
template < class T1, class T2 >

constexpr std:: pair < std:: unwrap_ref_decay_t < T1 > ,
std:: unwrap_ref_decay_t < T2 >>

make_pair ( T1 && x, T2 && y ) ;
(C++20から)

std::pair オブジェクトを作成し、引数の型からターゲット型を推論します。

std:: decay < T1 > :: type U1 とし、型 std:: decay < T2 > :: type U2 としたとき、型 /*V1*/ /*V2*/ は以下のように定義される:

  • U1 std:: reference_wrapper < X > の場合、 /*V1*/ X& となる。それ以外の場合、 /*V1*/ U1 となる。
  • U2 std:: reference_wrapper < Y > の場合、 /*V2*/ Y& となる。それ以外の場合、 /*V2*/ U2 となる。
(C++11以降)
(C++20まで)

目次

パラメータ

x, y - ペアを構築するための値

戻り値

std:: pair < T1, T2 > ( x, y )

(C++11まで)

std:: pair < /*V1*/ , /*V2*/ > ( std:: forward < T1 > ( x ) , std:: forward < T2 > ( y ) )

(C++11から)
(C++20まで)

std:: pair < std:: unwrap_ref_decay_t < T1 > , std:: unwrap_ref_decay_t < T2 >>
( std:: forward < T1 > ( x ) , std:: forward < T2 > ( y ) )

(C++20から)

#include <functional>
#include <iostream>
#include <utility>
int main()
{
    int n = 1;
    int a[5] = {1, 2, 3, 4, 5};
    // 2つのintからpairを構築
    auto p1 = std::make_pair(n, a[1]);
    std::cout << "The value of p1 is "
              << '(' << p1.first << ", " << p1.second << ")\n";
    // intへの参照と配列(ポインタに減衰)からpairを構築
    auto p2 = std::make_pair(std::ref(n), a);
    n = 7;
    std::cout << "The value of p2 is "
              << '(' << p2.first << ", " << *(p2.second + 2) << ")\n";
}

出力:

The value of p1 is (1, 2)
The value of p2 is (7, 3)

欠陥報告

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

DR 適用対象 公開時の動作 正しい動作
LWG 181 C++98 パラメータ型がconst参照型であり、
配列の受け渡しが不可能だった
これらの型を
値型に変更