STL map详细用法和make_pair函数

来源:互联网 发布:时时彩缩水软件 编辑:程序博客网 时间:2024/06/06 04:43

the source URL: http://www.cnblogs.com/ranjiewen/p/5901296.html
首先make_pairPairs C++标准程序库中凡是“必须返回两个值”的函数, 也都会利用pair对象 classpair可以将两个值视为一个单元。容器类别map和multimap就是使用pairs来管理其健值/实值(key/value)的成对元素。 pair被定义为struct,因此可直接存取pair中的个别值.两个pairs互相比较时, 第一个元素正具有较高的优先级. 例: namespace std{ template <class T1, class T2> bool operator< (const pair<T1, T2>&x, const pair<T1, T2>&y){ return x.first<y.first || ((y.first<x.first)&&x.second<y.second); } }make_pair():无需写出型别, 就可以生成一个pair对象 例: std::make_pair(42, '@'); 而不必费力写成: std::pair<int, char>(42, '@')当有必要对一个接受pair参数的函数传递两个值时, make_pair()尤其显得方便, void f(std::pair<int, const char*>);void foo{ f(std::make_pair(42, '@')); //pass two values as pair }1 pair的应用pair是将2个数据组合成一个数据,当需要这样的需求时就可以使用pair,如stl中的map就是将key和value放在一起来保存。另一个应用是,当一个函数需要返回2个数据的时候,可以选择pair。 pair的实现是一个结构体,主要的两个成员变量是first second 因为是使用struct不是class,所以可以直接使用pair的成员变量。2 make_pair函数template pair make_pair(T1 a, T2 b) { return pair(a, b); }很明显,我们可以使用pair的构造函数也可以使用make_pair来生成我们需要的pair。 一般make_pair都使用在需要pair做参数的位置,可以直接调用make_pair生成pair对象很方便,代码也很清晰。 另一个使用的方面就是pair可以接受隐式的类型转换,这样可以获得更高的灵活度。灵活度也带来了一些问题如:std::pair<int, float>(1, 1.1);std::make_pair(1, 1.1);是不同的,第一个就是float,而第2个会自己匹配成double。map:Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力,由于这个特性,它完成有可能在我们处理一对一数据的时候,在编程上提供快速通道。这里说下map内部数据的组织,map内部自建一颗红黑树(一种非严格意义上的平衡二叉树),这颗树具有对数据自动排序的功能,所以在map内部所有的数据都是有序的,后边我们会见识到有序的好处。下面举例说明什么是一对一的数据映射。比如一个班级中,每个学生的学号跟他的姓名就存在着一一映射的关系,这个模型用map可能轻易描述,很明显学号用int描述,姓名用字符串描述(本篇文章中不用char *来描述字符串,而是采用STL中string来描述),下面给出map描述代码:Map<int, string> mapStudent;1.       map的构造函数map共提供了6个构造函数,这块涉及到内存分配器这些东西,略过不表,在下面我们将接触到一些map的构造方法,这里要说下的就是,我们通常用如下方法构造一个map:Map<int, string> mapStudent;2.       数据的插入在构造map容器后,我们就可以往里面插入数据了。这里讲三种插入数据的方法:第一种:用insert函数插入pair数据,下面举例说明(以下代码虽然是随手写的,应该可以在VC和GCC下编译通过,大家可以运行下看什么效果,在VC下请加入这条语句,屏蔽4786警告  #pragma warning (disable:4786) )#include <map>#include <string>#include <iostream>Using namespace std;Int main(){       Map<int, string> mapStudent;       mapStudent.insert(pair<int, string>(1, “student_one”));       mapStudent.insert(pair<int, string>(2, “student_two”));       mapStudent.insert(pair<int, string>(3, “student_three”));       map<int, string>::iterator  iter;       for(iter = mapStudent.begin(); iter != mapStudent.end(); iter++){       Cout<<iter->first<<”   ”<<iter->second<<end;}}第二种:用insert函数插入value_type数据,下面举例说明#include <map>#include <string>#include <iostream>Using namespace std;Int main(){       Map<int, string> mapStudent;       mapStudent.insert(map<int, string>::value_type (1, “student_one”));       mapStudent.insert(map<int, string>::value_type (2, “student_two”));       mapStudent.insert(map<int, string>::value_type (3, “student_three”));       map<int, string>::iterator  iter;       for(iter = mapStudent.begin(); iter != mapStudent.end(); iter++){       Cout<<iter->first<<”   ”<<iter->second<<end;}}第三种:用数组方式插入数据,下面举例说明#include <map>#include <string>#include <iostream>Using namespace std;Int main(){       Map<int, string> mapStudent;       mapStudent[1] =  “student_one”;       mapStudent[2] =  “student_two”;       mapStudent[3] =  “student_three”;       map<int, string>::iterator  iter;       for(iter = mapStudent.begin(); iter != mapStudent.end(); iter++){       Cout<<iter->first<<”   ”<<iter->second<<end;}}以上三种用法,虽然都可以实现数据的插入,但是它们是有区别的,当然了第一种和第二种在效果上是完成一样的,用insert函数插入数据,在数据的插入上涉及到集合的唯一性这个概念,即当map中有这个关键字时,insert操作是插入数据不了的,但是用数组方式就不同了,它可以覆盖以前该关键字对应的值,用程序说明mapStudent.insert(map<int, string>::value_type (1, “student_one”));mapStudent.insert(map<int, string>::value_type (1, “student_two”));上面这两条语句执行后,map中1这个关键字对应的值是“student_one”,第二条语句并没有生效,那么这就涉及到我们怎么知道insert语句是否插入成功的问题了,可以用pair来获得是否插入成功,程序如下Pair<map<int, string>::iterator, bool> Insert_Pair;Insert_Pair = mapStudent.insert(map<int, string>::value_type (1, “student_one”));我们通过pair的第二个变量来知道是否插入成功,它的第一个变量返回的是一
原创粉丝点击