源自: http://blog.sina.com.cn/s/blog_72a0bac20100qbg6.html
自己写了个小的Test:
- #include <iostream>
- #include<vector>
- using namespace std;
- typedef vector<pair<int, int> > Type_vector;
- int main(int argc, char *argv[])
- {
- vector<pair<int, int> > xiaoqiang;
- xiaoqiang.push_back(make_pair(3,4));
- //vector<pair<int, int> >::iterator iter;
- Type_vector::iterator iter;
- for(iter = xiaoqiang.begin(); iter!=xiaoqiang.end(); iter++)
- {
- cout<<iter->first<<" : "<<iter->second<<endl;
- }
- return 0;
- }
- std::pair主要的作用是将两个数据组合成一个数据,两个数据可以是同一类型或者不同类型。例如std::pair<int,float> 或者 std::pair<double,double>等。pair实质上是一个结构体,其主要的两个成员变量是first和second,这两个变量可以直接使用。初始化一个pair可以使用构造函数,也可以使用std::make_pair函数,make_pair函数的定义如下:
- template pair make_pair(t1 a, t2 b) { return pair(a, b); }
- 一般make_pair都使用在需要pair做参数的位置,可以直接调用make_pair生成pair对象。另一个使用的方面就是pair可以接受隐式的类型转换,这样可以获得更高的灵活度。但是这样会出现如下问题:例如有如下两个定义:
- std::pair<int, float>(1, 1.1);
- std::make_pair(1, 1.1);
- 其中第一个的second变量是float类型,而make_pair函数会将second变量都转换成double类型。这个问题在编程是需要引起注意。下面是一段pair与make_pair的例子程序:
- 1 #include <iostream>
- 2 #include <utility>
- 3 #include <string>
- 4 using namespace std;
- 5
- 6 int main () {
- 7 pair <string,double> product1 ("tomatoes",3.25);
- 8 pair <string,double> product2;
- 9 pair <string,double> product3;
- 10
- 11 product2.first = "lightbulbs"; // type of first is string
- 12 product2.second = 0.99; // type of second is double
- 13
- 14 product3 = make_pair ("shoes",20.0);
- 15
- 16 cout << "the price of " << product1.first << " is $" << product1.second << "\n";
- 17 cout << "the price of " << product2.first << " is $" << product2.second << "\n";
- 18 cout << "the price of " << product3.first << " is $" << product3.second << "\n";
- 19 return 0;
- 20 }
- 其运行结果如下:
- 1 the price of tomatoes is $3.25
- 2 the price of lightbulbs is $0.99
- 3 the price of shoes is $20
- 为了更好的了解pair与make_pair的机制,下面是其定义:
- 1 // template struct pair
- 2 template<class _ty1,class _ty2> struct pair
- 3 { // store a pair of values
- 4 typedef pair<_ty1, _ty2> _myt;
- 5 typedef _ty1 first_type;
- 6 typedef _ty2 second_type;
- 7
- 8 pair(): first(_ty1()), second(_ty2())
- 9 { // construct from defaults
- 10 }
- 11
- 12 pair(const _ty1& _val1, const _ty2& _val2): first(_val1), second(_val2)
- 13 { // construct from specified values
- 14 }
- 15
- 16 template<class _other1,
- 17 class _other2>
- 18 pair(const pair<_other1, _other2>& _right)
- 19 : first(_right.first), second(_right.second)
- 20 { // construct from compatible pair
- 21 }
- 22
- 23 void swap(_myt& _right)
- 24 { // exchange contents with _right
- 25 std::swap(first, _right.first);
- 26 std::swap(second, _right.second);
- 27 }
- 28
- 29 _ty1 first; // the first stored value
- 30 _ty2 second; // the second stored value
- 31 };
- 32
- 33
- 34 template<class _ty1,class _ty2> inline
- 35 pair<_ty1, _ty2> make_pair(_ty1 _val1, _ty2 _val2)
- 36 { // return pair composed from arguments
- 37 return (pair<_ty1, _ty2>(_val1, _val2));
- 38 }