std::get(std::pair)
来自 cppreference.cn
在头文件 <utility> 中定义 |
||
template< std::size_t I, class T1, class T2 > typename std::tuple_element<I, std::pair<T1,T2> >::type& |
(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& |
(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&& |
(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&& |
(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)接口提取 pair 中的元素。
1-4) 如果索引 `I` 既不是 0 也不是 1,则基于索引的重载无法编译。
5-12) 如果类型 `T` 和 `U` 相同,则基于类型的重载无法编译。
目录 |
[编辑] 参数
p | - | 要提取内容的 pair |
[编辑] 返回值
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)
[编辑] 缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 发布时的行为 | 正确的行为 |
---|---|---|---|
LWG 2485 | C++11(按索引) C++14(按类型) |
没有针对 const pair&& 的重载 | 添加重载 |
[编辑] 参阅
结构化绑定 (C++17) | 将指定名称绑定到初始化器的子对象或元组元素 |
(C++11) |
tuple 访问指定的元素 (函数模板) |
(C++11) |
访问 array 的一个元素(函数模板) |
(C++17) |
根据索引或类型(如果类型唯一)读取变体的值,出错时抛出异常 (函数模板) |
(C++20) |
从 std::ranges::subrange 获取迭代器或哨兵 (函数模板) |
(C++26) |
从 std::complex 获取实部或虚部的引用 (函数模板) |