std::make_pair

< cpp‎ | utility‎ | pair
在标头 <utility> 定义
template< class T1, class T2 >
std::pair<T1, T2> make_pair( T1 t, T2 u );
(C++11 前)
template< class T1, class T2 >
std::pair<V1, V2> make_pair( T1&& t, T2&& u );
(C++11 起)
(C++14 起为 constexpr)

创建 std::pair 对象,从实参类型推导目标类型。

推导结果类型 V1V2std::decay<T1>::typestd::decay<T2>::type(即对按值传递的函数实参应用的常规类型变换),除非应用 std::decay 到某类型 X 产生 std::reference_wrapper<X>,此时推导结果类型是 X&

(C++11 起)

参数

t, u - 构造对偶所用的值

返回值

含有给定值的 std::pair 对象。

示例

#include <functional>
#include <iostream>
#include <utility>
 
int main()
{
    int n = 1;
    int a[5] = {1, 2, 3, 4, 5};
 
    // 从两个 int 建造 pair
    auto p1 = std::make_pair(n, a[1]);
    std::cout << "p1 的值是 "
              << '(' << p1.first << ", " << p1.second << ")\n";
 
    // 从到 int 的引用和数组(退化成指针)建造 pair
    auto p2 = std::make_pair(std::ref(n), a);
    n = 7;
    std::cout << "p2 的值是 "
              << '(' << p2.first << ", " << *(p2.second + 2) << ")\n";
}

输出:

p1 的值是 (1, 2)
p2 的值是 (7, 3)

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 181 C++98 形参类型是 const 引用类型,这导致无法传递数组 将形参类型改成值类型

参阅

获取包装于 std::reference_wrapper 的引用类型
(类模板)