C++ pair和make_pair用法_C++ STL成对数据存储操作步骤

c++kquote>pair是C++ STL中存储两个不同数据的容器,常用于键值对等场景;make_pair可自动推导类型,简化创建过程;pair定义在utility头文件中,通过first和second访问元素;支持字典序比较,广泛应用于map、unordered_map及vector排序中,提升代码简洁性与效率。

在C++ STL中,pair 是一种能够存储两个不同类型数据的容器,常用于需要成对保存数据的场景,比如映射关系、函数返回多个值、STL容器中的键值对等。而 make_pair 是一个便捷函数,用于快速创建 pair 对象,避免手动指定类型。

pair 的基本用法

pair 定义在 utility 头文件中(通常包含 或直接使用 ),可以保存两个元素,分别称为 firstsecond

定义方式如下:

  • std::pair p1 = {1, "Alice"};
  • std::pair p2(3.14, true);

访问元素使用点操作符:

  • p1.first // 获取第一个元素
  • p1.second // 获取第二个元素

make_pair 的作用与优势

make_pair 可以自动推导类型,简化 pair 的创建过程,无需显式写出模板参数。

  • auto p = make_pair(10, "Bob"); —— 等价于 pair
  • auto p3 = make_pair("key", 100);

这在函数传参或插入容器时特别方便,比如:

std::vector<:pair int>> vec;
vec.push_back(make_pair(1, 2));

pair 在 STL 容器中的典型应用

pair 最常见的用途之一是配合 mapunordered_map 使用,这些容器的每个元素本质上就是一个 pair。

  • std::map m;
    m[1] = "John";
    // 或插入:m.insert(make_pair(1, "John"));

在遍历时,迭代器指向的是 pair 类型:

for (const auto& kv : m) {
  std::cout }

pair 的比较与排序

pair 支持默认的字典序比较,先比较 first,再比较 second,适用于排序和 set 中的自动排序。

  • (1, 3) —— 成立,因为 1
  • (2, 1) —— 成立,first 相等时比较 second

可直接用于 vector 排序:

std::vector<:pair int>> points = {{2, 3}, {1, 4}, {2, 1}};
std::sort(points.begin(), points.end());

基本上就这些。合理使用 pair 和 make_pair 能让代码更简洁清晰,尤其在处理键值对、坐标、临时数据组合时非常高效。不复杂但容易忽略细节,比如类型匹配和自动推导规则。