std::map用法

std::map用法
   STL是标准C++系统的一组模板类,使用STL模板类最大的好处就是在各种C++编译器上都通用。
   在STL模板类中,用于线性数据存储管理的类主要有vector, list, map 等等。本文主要针对map对象,结合自己学习该对象的过程,讲解一下具体用法。本人初学,水平有限,讲解差错之处,请大家多多批评指正。
    map对象所实现的功能跟MFC得CMap相似,但是根据一些文章的介绍和论述,MFC CMap在个方面都与STL map有一定的差距,例如不是C++标准,不支持赋值构造,对象化概念不清晰等等。
  使用map对象首先要包括头文件,包含语句中必须加入如下包含声明
#include <map>
注意,STL头文件没有扩展名.h
包括头文件后就可以定义和使用map对象了,map对象是模板类,需要关键字和存储对象两个模板参数,例如:
std:map<int, CString> enumMap;
这样就定义了一个用int作为关键字检索CString条目的map对象,std表示命名空间,map对象在std名字空间中,为了方便,在这里我仍然使用了CString类,其实应该使用标准C++的std::string类,我们对模板类进行一下类型定义,这样用的方便,当然,不定义也可以,代码如下:
typedef std:map<int, CString> UDT_MAP_INT_CSTRING;
UDT_MAP_INT_CSTRING enumMap;
如此map对象就定义好了,增加,改变map中的条目非常简单,因为map类已经对[]操作符进行了重载,代码如下:
enumMap[1] = "One";
enumMap[2] = "Two";
.....
enumMap[1] = "One Edit";
或者insert方法
enumMap.insert(make_pair(1,"One"));
 
返回map中目前存储条目的总数用size()方法:
int nSize = enumMap.size();
 
查找map中是否包含某个关键字条目用find方法,传入的参数是要查找的key,在我们的例子里,是一个int数据,map中的条目数据是顺序存储的,被称作为一个sequence,在这里需要提到的是begin()和end()两个成员,分别代表map对象中第一个条目和最后一个条目,这两个数据的类型是iterator,iterator被定义为map中条目的类型,查找是否包含某个条目的代码如下:
int nFindKey = 2;            //要查找的Key
UDT_MAP_INT_CSTRING::iterator it;    //定义一个条目变量(实际是指针)
it = enumMap.find(nFindKey);
if(it == enumMap.end()) {
    //没找到
}
else {
    //找到
}
//find的时候注意key的数据类型,最好用CString之类的能消除数据类型差异的key,否则可能会出现强制转换后仍找不到的情况。
需要说明的是iterator, begin(), end()是STL模板类的一个通用概念,操作方法也大同小异
通过map对象的方法获取的iterator数据类型是一个std::pair对象,包括两个数据 iterator.first 和 iterator.second 分别代表关键字和存储的数据
移除某个条目用erase() 该成员方法的定义如下
iterator erase(iterator it);
iterator erase(iterator first, iterator last);
size_type erase(const Key& key);
分析一下这三个重载方法定义,大家不用说也能看明白一点点了吧,第一个通过一个条目对象删除,这个对象可以从find之类的方法获得,第二个定义删除一个范围,需要一个起始条目和一个终止条目,第三个通过关键字删除,这个与我们的想法和习惯最接近,代码例子如下:
enumMap.erase(1);            //删掉关键字“1”对应的条目
enumMap.erase(enumMap.begin());        //删掉第一个条目
enumMap.erase(enumMap.begin(), enumMap.begin() + 1);    //删掉起始的两个条目
呵呵,增删改查都说完了,相信读过本文,map对象也应该会使用了,这些是我1个多星期来钻研的结果,拿出来与大家分享。
最后,还有一个clear(),不用问,全删的时候就不要一个一个erase了,clear()就相当于enumMap.erase(enumMap.begin(), enumMap.end());
 
map的遍历:
#include<map>
#include<string>
#include<iostream>
using namespace std;

int main()
{
      map<string,int>  m;
      m["a"]=1;
      m["b"]=2;
      m["c"]=3;
      map<string,int>::iterator it;
      for(it=m.begin();it!=m.end();++it)
            cout<<"key: "<<it->first <<" value: "<<it->second<<endl;
      return    0;
}

 
map<string,int>::iterator it;    定义一个迭代指针it。 
it->first 为索引键值,it->second 为值。

 
在对象中应用时,最好在析构函数中要调用它的clear方法,
例如class a{
    map<int,int> m;
 
   ~a(){
    m.clear();
  }
}
  • 12
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
std::map是C++标准库中的一个关联容器,它提供了一种键值对的映射关系。下面是std::map的使用方法: 1. 包含头文件:首先需要包含<map>头文件。 2. 定义map对象:使用std::map<key_type, value_type>来定义一个map对象,其中key_type是键的类型,value_type是值的类型。例如,可以定义一个存储整数到字符串的映射关系的map对象:std::map<int, std::string> myMap; 3. 插入元素:可以使用insert()函数向map中插入元素。插入元素时需要指定键和值。例如,可以插入一个键值对(1, "one")到myMap中:myMap.insert(std::make_pair(1, "one")); 4. 访问元素:可以使用[]运算符或者at()函数来访问map中的元素。例如,可以通过键1来访问对应的值:"std::cout << myMap;" 或者 "std::cout << myMap.at(1);" 5. 查找元素:可以使用find()函数来查找指定键的元素。如果找到了,则返回指向该元素的迭代器;如果没有找到,则返回指向末尾的迭代器。例如,可以查找键为1的元素:auto it = myMap.find(1); if (it != myMap.end()) { // 找到了元素 } 6. 删除元素:可以使用erase()函数来删除指定键的元素。例如,可以删除键为1的元素:myMap.erase(1); 7. 遍历元素:可以使用迭代器来遍历map中的所有元素。例如,可以使用for循环遍历myMap中的所有键值对:for (auto it = myMap.begin(); it != myMap.end(); ++it) { std::cout << it->first << ": " << it->second << std::endl; } 8. 其他操作:std::map还提供了一些其他的操作,如获取map的大小(size())、判断map是否为空(empty())等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值