C++ pair的用法案例詳解
一、介紹
pair是將2個(gè)數(shù)據(jù)組合成一組數(shù)據(jù),當(dāng)需要這樣的需求時(shí)就可以使用pair。當(dāng)然你也可以自定義一個(gè)結(jié)構(gòu)體struct。不過(guò)大家都是為了方便,所以就直接用pair了。
pair的實(shí)現(xiàn)是一個(gè)結(jié)構(gòu)體,主要的兩個(gè)成員變量是first second 因?yàn)槭鞘褂胹truct不是class,所以可以直接使用pair的成員變量。
其標(biāo)準(zhǔn)庫(kù)類型--pair類型定義在#include <utility>頭文件中,定義如下:
類模板:
template<class T1,class T2> struct pair
參數(shù):T1是第一個(gè)值的數(shù)據(jù)類型,T2是第二個(gè)值的數(shù)據(jù)類型。
二、構(gòu)造函數(shù)
pair<T1, T2> p1; //創(chuàng)建一個(gè)空的pair對(duì)象(使用默認(rèn)構(gòu)造),它的兩個(gè)元素分別是T1和T2類型,采用值初始化。 pair<T1, T2> p1(v1, v2); //創(chuàng)建一個(gè)pair對(duì)象,它的兩個(gè)元素分別是T1和T2類型,其中first成員初始化為v1,second成員初始化為v2。 make_pair(v1, v2); // 以v1和v2的值創(chuàng)建一個(gè)新的pair對(duì)象,其元素類型分別是v1和v2的類型。
make_pair的用法
無(wú)需寫出型別, 就可以生成一個(gè)pair對(duì)象
例:
std::make_pair(42, '@');
而不必費(fèi)力寫成:
std::pair<int, char>(42, '@')
當(dāng)有必要對(duì)一個(gè)接受pair參數(shù)的函數(shù)傳遞兩個(gè)值時(shí), make_pair()尤其顯得方便,
void function(std::pair<int, const char*>); void foo{ function(std::make_pair(42, '@')); //pass two values as pair }
三、使用
pair<int, double> p1; p1 = make_pair(1, 1.2); cout << p1.first << p1.second << endl; //output: 1 1.2 int a = 8; string m = "James"; pair<int, string> newone; newone = make_pair(a, m); cout << newone.first << newone.second << endl; //output: 8 James
在某些清況函數(shù)會(huì)以pair對(duì)象作為返回值時(shí),可以直接通過(guò)std::tie進(jìn)行接收。比如
#include <utility> #include <iostream> using namespace std; std::pair<std::string, int> getPreson() { return std::make_pair("Sven", 25); }; int main(int argc, char **argv) { std::string name; int ages; std::tie(name, ages) = getPreson(); std::cout << "name: " << name << ", ages: " << ages << std::endl; return 0; }
參考:
https://blog.csdn.net/weixin_42825576/article/details/81571419
https://blog.csdn.net/sevenjoin/article/details/81937695
到此這篇關(guān)于C++ pair的用法案例詳解的文章就介紹到這了,更多相關(guān)C++ pair的用法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語(yǔ)言實(shí)現(xiàn)大學(xué)生考勤管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)大學(xué)生考勤管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12C++實(shí)現(xiàn)LeetCode(126.詞語(yǔ)階梯之二)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(126.詞語(yǔ)階梯之二),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07C語(yǔ)言實(shí)現(xiàn)掃雷游戲(含注釋詳解)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)掃雷游戲,含注釋,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06解析在main函數(shù)之前調(diào)用函數(shù)以及對(duì)設(shè)計(jì)的作用詳解
本篇文章是對(duì)在main函數(shù)之前調(diào)用函數(shù)以及對(duì)設(shè)計(jì)的作用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05Qt項(xiàng)目實(shí)戰(zhàn)之方塊游戲的實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了如何利用Qt實(shí)現(xiàn)簡(jiǎn)易的方塊游戲,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴可以了解一下2023-03-03C++?JSON庫(kù)?nlohmann::basic_json::accept的用法解析
nlohmann::basic_json::accept 是 Nlohmann JSON 庫(kù)中的一個(gè)方法,它用于檢查一個(gè)字符串是否可以解析為有效的 JSON,這篇文章主要介紹了C++?JSON庫(kù)nlohmann::basic_json::accept的用法,需要的朋友可以參考下2023-06-06