当前位置:  编程技术>c/c++/嵌入式

关于STL中的map容器的一些总结

    来源: 互联网  发布时间:2014-10-20

    本文导语:  一、关于map的介绍 map是STL的一个容器,和set一样,map也是一种关联式容器。它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力,由于这个特性,有助...

一、关于map的介绍

map是STL的一个容器,和set一样,map也是一种关联式容器。它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力,由于这个特性,有助于我们处理一对一数据。这里说下map内部数据的组织,map内部是自建一颗红黑树(一种非严格意义上的平衡二叉树),这颗树具有对数据自动排序的功能,所以在map内部所有的数据都是有序的。学习map我们一定要理解什么是一对一的数据映射?比如:一个班级中,每个学生的学号跟他的姓名就存在着一一映射的关系,这个模型用map可能轻易描述,很明显学号用int 描述,姓名用字符串描述采用的string,于是我们使用的map形式如下:map student;

这里说一下map和set容器的区别。

对于map中的每个节点存储的是一对信息,包括一个键和一个值,各个节点之间的键值不能重复。

对于set中的每个节点存储的是一个信息,只有一个键,但是每个键值也是唯一的。set表示的是集合的概念。

对于map的学习,或者说是对STL中的容器的学习,要知道每种容器的实现原理,每种适合适合解决什么问题的,才是关键~~~~

二、map中常用的操作

2.1 map中的构造函数

代码如下:

map(); // 默认构造函数

map(const map& m) // 拷贝构造函数

map(iterator begin, iterator end ); //区间构造函数

map(iterator begin, iterator end, const traits& _compare) //带比较谓词的构造函数

map(iterator begin, iterator end, const traits& _compare, const allocator& all) //带分配器


经过分析我们发现,map的构造函数主要是调用“拷贝构造函数”和利用“迭代器”进行初始化两种方式。我想原因是很简单的,因为,map中每个节点由一对值构成。这里还用写一个程序演示一下map的构造函数吗?

2.2 map中的一些基础函数
begin,end,rbegin,rend,empty,clear,size,max_size。八个常用的函数,看到名字应该就知道怎么用了吧,看看代码:

代码如下:

#pragma warning (disable:4786)

#include
#include
#include

using namespace std;

int main()
{
    map studentMessage;
    map::iterator iter;
    studentMessage.insert(pair(54090101,"Mike"));
    studentMessage.insert(pair(54090102,"Sam"));
    studentMessage.insert(pair(54090103,"Jake"));
    //begin获取map中的第一个元素的迭代器,并且等于rend
    //end获取map中的最后一个元素下一位置的迭代器,并且等于rbegin
    cout


    
 
 

您可能感兴趣的文章:

  • c++ stl容器set成员函数介绍及set集合插入,遍历等用法举例
  • 请问STL中的所有容器(map,multimap,list,queue,vector,set,multiset.......)在BOOST中都可以找到么
  • c++ stl容器vector删除(erase),遍历等基本用法介绍及头文件
  • STL各个容器性能详细比较
  • c++ stl栈容器stack的pop(),push()等用法介绍及头文件
  • 过河小兵,求救各位大哥,我想把stl中的map,vector等容器,做成内存共享方式,希望大哥大姐们指点一下
  • c++ STL关联式容器Map成员函数介绍及查找(find()),插入(insert()),删除(erase())等操作代码举例
  • 浅析stl序列容器(map和set)的仿函数排序
  • 双向队列Deque 类成员函数列表参考(c++ STL 容器)
  • stl容器set,map,vector之erase用法与返回值详细解析
  • STL常用容器详细解析
  • 深入解析C++ STL中的常用容器
  • 关于STL中list容器的一些总结
  • c++ STL容器总结之:vertor与list的应用
  • 关于STL中set容器的一些总结
  • 关于STL中vector容器的一些总结
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 我想把STL中的vector,map,set,multimap,multiset的所有操作修改成线程安全的,可以么
  • STL map在使用过程中用了clear为什么在Top as中还是看不到内存释放呢?
  • 关于模板实例化和STL::map
  • 请问如果我想利用stl::map重新生成一个类,下面的写法为什么出错
  • 关于redhat Linux ,g++下stl库map内存释放的问题
  • C++ STL Bitsets构造函数及成员函数解释及代码示例
  • SGI的STL库 SGI STL
  • STL vector+sort排序和multiset/multimap排序比较
  • STL 在 UNIX 多线程 中不能用? iis7站长之家
  • C++ STL标准模板库类String成员详细列表参考及示例代码
  • linux完全支持C++STL嗎?
  • C++ stl队列Queue用法介绍:删除,插入等操作代码举例
  • 是不是只有C++才可以使用STL?
  • C++ STL库中priority_queue介绍,成员函数说明及priority_queue具体用法举例
  • STL 在 UNIX 多线程 中不能用?
  • c++ stl multimap基本操作使用技巧详细介绍
  • Linux系统下如何获取STL帮助
  • c++ STL List查找遍历及各成员函数用法详细介绍
  • STL实现 EASTL
  • C++ STL MultiSet类成员函数介绍及具体用法示例
  • 在COMPAQ TRUE64 UNIX用C++编程,使用Gcc,支不支持stl?
  • 哪儿能下载aix4.3的c++ stl库
  • 请问在linux下面编程怎样查询stl类的成员函数
  • 关于stl源代码
  • 请问如果要同时使用STL和多线程,会很麻烦么
  • linux下用c语言写的程序,其中可以使用STL模板吗?先谢谢各位




  • 特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3