std::get(std::pair)
來自 cppreference.com
在標頭檔案 <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 獲取實部或虛部的引用 (函式模板) |