std::make_pair

来自cppreference.com
< cpp‎ | utility‎ | pair
 
 
工具库
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)
(C++20)
swap 与类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)
 
std::pair
成员函数
(C++11)
非成员函数
make_pair
(C++20 前)(C++20 前)(C++20 前)(C++20 前)(C++20 前)(C++20)
(C++11)
(C++11)
推导指引(C++17)
辅助类
(C++11)
 
在标头 <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 前)
template< class T1, class T2 >
constexpr std::pair<V1, V2> make_pair( T1&& t, T2&& u );
(C++14 起)

构造 std::pair 对象,从参数类型推导目标类型。

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

(C++11 起)

参数

t, u - 构造 pair 所用的值

返回值

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

示例

#include <iostream>
#include <utility>
#include <functional>
 
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 的引用类型
(类模板)