map--C++ STL 学习
map–C++ STL 学习
Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力。
说下map内部数据的组织,map内部自建一颗红黑树(一种非严格意义上的平衡二叉树),这颗树具有对数据自动排序的功能,所以在map内部所有的数据都是有序的。
map是使用红黑树实现的,访问、查找和删除操作的复杂度都是O(logn)。
template<
class Key, //键
class T, //值
class Compare = std::less<Key>, //
class Allocator = std::allocator<std::pair<const Key, T>
> class map;
(1)map的创建
map共提供了6个构造函数,这块涉及到内存分配器这些东西,略过不表,在下面我们将接触到一些map的构造方法,这里要说下的就是,我们通常用如下方法构造一个map:
Map<int, string> mapStudent;
(2)遍历操作
遍历map无疑就需要使用到迭代器,下面列出了四种map迭代器
iterator begin(); //返回指向起始元素的迭代器
iterator rbegin(); //返回指向末尾元素的迭代器
iterator end(); //返回指向末尾元素的后一个的迭代器
iterator rend(); //返回指向起始元素的前一个的迭代器
(3)插入操作
1.使用[]插入
直接使用[]插入,如果mymap中不存在键值为”abc”元素,那么就执行插入操作。
mymap["abc"] = 1;
2.插入单个元素
//函数原型:
std::pair<iterator,bool> insert( const value_type& value ); //这里的返回值:bool表示插入是否成功、iterator返回插入的位置
//操作示例:
mymap.insert( map<int, string>::value_type(1, "one") );
3.插入多个元素
//函数原型:
template< class InputIt >
void insert( InputIt first, InputIt last );
//操作示例:
map<int, string> tmp = {
{5, "five"},
{6, "six"}
};
mymap.insert( tmp.begin(),tmp.end() );
4. 使用std::initializer_list插入
C++11中新加入的插入数据方式:
//函数原型:
void insert( std::initializer_list<value_type> ilist );
//操作示例:
mymap.insert( { {7, "seven"}, {8, "eight"}, {9, "nine"} } );
(4)删除操作
1. 删除指定位置的元素
//函数原型:
iterator erase( iterator pos );
//具体示例:
std::map<std::string,int>::iterator it = mymap.erase(mymap.begin()); //返回删除元素的下一个元素的迭代器
2. 删除指定范围的元素
//函数原型:
iterator erase( const_iterator first, const_iterator last );
//具体示例:
mymap.erase(mymap.begin(), mymap.end()); //删除所有的元素
3. 依据键值删除元素
//函数原型:
size_type erase( const key_type& key );
//具体示例:
int num = mymap.erase("abc");
PS:方法一和方法二的返回值都是删除元素的下一个元素的迭代器,在C++11之前他们都是没有返回值的。方法三的返回值是删除元素的数目。
(5)max_size(),最大容纳量;size(),当前的元素个数
cout << "map中的最大容量为:" << map1.max_size() << endl;
cout << "map中的元素个数为:" << map1.size() << endl;
(6)empty(),判断map是否为空
cout << "map是否为空:" << map1.empty() << endl;
如果为空,返回1.否则返回0。
(7)swap():交换两个map中的值。
(8)[],at(),取某位置的元素值
// 取map中某位置的元素值
cout << "在1位置的元素值为:" << map1.at(1) << endl;
cout << "在1位置的元素值为:" << map1[1] << endl;
(9)[],at():修改元素
// 修改map中的某个值
map1[2] = 99;
map1.at(3) = 88;
(10)clear():清除所有元素
// 清除所有数据
map1.clear();
cout << "map是否为空:" << map1.empty() << endl;
执行以后就是一个空的map,不包含任何元素。
其他方法
size_type count( const Key& key ) const; //返回关键字为key的元素的个数,在map里结果不是0就是1
iterator find( const Key& key ); //返回key所在位置的迭代器,如果没有找到则返回end()
关于map的更详细介绍可以参考文档:http://en.cppreference.com/w/cpp/container/map
map--C++ STL 学习的更多相关文章
- STL学习:STL库vector、string、set、map用法
本文仅介绍了如何使用它们常用的方法. vector 1.可随机访问,可在尾部插入元素:2.内存自动管理:3.头文件#include <vector> 1.创建vector对象 一维: (1 ...
- 侯捷STL学习(九)--关联式容器(Rb_tree,set,map)
layout: post title: 侯捷STL学习(九) date: 2017-07-21 tag: 侯捷STL --- 第十九节 容器rb_tree Red-Black tree是自平衡二叉搜索 ...
- 侯捷STL学习(十)--容器hashtable探索(unordered set/map)
layout: post title: 侯捷STL学习(十) date: 2017-07-23 tag: 侯捷STL --- 第二十三节 容器hashtable探索 hashtable冲突(碰撞)处理 ...
- 标准模板库(STL)学习指南之map映射
转载自CSDN博客:http://blog.csdn.net/bat603/article/details/1456141 Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关 ...
- 标准模板库(STL)学习探究之stack
标准模板库(STL)学习探究之stack queue priority_queue list map/multimap dequeue string
- ###STL学习--vector
点击查看Evernote原文. #@author: gr #@date: 2014-08-11 #@email: forgerui@gmail.com vector的相关问题.<stl学习> ...
- ###STL学习--关联容器
点击查看Evernote原文. #@author: gr #@date: 2014-08-23 #@email: forgerui@gmail.com STL中的关联容器. ###stl学习 |--迭 ...
- ###STL学习--迭代器
点击查看Evernote原文. #@author: gr #@date: 2014-08-23 #@email: forgerui@gmail.com STL中的迭代器. ###stl学习 |--迭代 ...
- ###STL学习--函数对象
点击查看Evernote原文. #@author: gr #@date: 2014-08-13 #@email: forgerui@gmail.com 在stl中,函数对象被大量地使用,用以提高代码的 ...
随机推荐
- C#Windows服务:一些方法(启动、停止等)
前面讲述了如何创建和安装服务(创建windows服务),下面把启动.停止.判断是否启动的方法也写一下. /// <summary> /// 判断是否安装了某个服务 /// </sum ...
- iOS开发技巧——关闭Autoresizing开启Autolayout
在使用Autolayout时有时候会有莫名其妙的错误,是因为UIView是默认同时开启Autoresizing和Autolayout的. 但我们的Autolayout很容易和Autoresizing冲 ...
- linux下分区相关知识
Linux 规定了主分区(或者扩展分区)占用 1 至 16 号码中的前 4 个号码.以第一个 IDE 硬盘为例说明,主分区(或者扩展分区)占用了 hda1.hda2.hda3.hda4,而逻辑分区占用 ...
- netstat 用法
https://linux.cn/article-2434-1.html Netstat 命令用于显示各种网络相关信息,如网络连接,路由表,接口状态 (Interface Statistics),ma ...
- zk client获取数据
获取数据 它返回znode的关联数据和指定znode的元数据.你将获得信息,例如上次修改数据的时间,修改的位置以及数据的相关信息.此CLI还用于分配监视器以显示数据相关的通知. 语法 get /pat ...
- 几种常用的json序列化和反序列化工具介绍
一.前言 Json序列化和反序列化工作中会时常用到,也是目前数据交互的常用格式,Rest风格的接口加上json格式的数据交互,真的是天作之合. 目前Json字符与Json对象的相互转换方式有很多,接下 ...
- VUE ---(9)组件——props数据传递
本篇资料来于官方文档: http://cn.vuejs.org/guide/components.html#Props 本文是在官方文档的基础上,更加细致的说明,代码更多更全. 简单来说,更适合新手阅 ...
- Kubernetes Fluentd+Elasticsearch+Kibana统一日志管理平台搭建的填坑指南
在初步完成Kubernetes集群架构的建立后,通过搭建一些监控组件,我们已经能够实现 图形化的监控每个node,pod的状态信息和资源情况 通过scale进行replicateSet的扩展和伸缩 通 ...
- WebLogic MBean Monitor
weblogic server提供了一个dashboard让我们对mbean进行图形化的展现和分析,地址是 http://localhost:7001/console/dashboard 但有时候总是 ...
- JSONObject和JSONArray(json-lib-2.4)的基本用法
json-lib-2.4是一个用于JSON和java对象间转换的第三方包,其jar和依赖包下载地址在:https://files.cnblogs.com/files/xiandedanteng/jso ...