博客
关于我
c++标准库中的关联容器
阅读量:271 次
发布时间:2019-03-01

本文共 1085 字,大约阅读时间需要 3 分钟。

关键字有序的:

1、map 保存key:value,key不可重复

2、set 保存key,key不可重复

3、multimap 保存key可重复出现的key:value

4、multiset 保存key可重复出现的key

关键字无序的:

1、unordered_map

2、unordered_set 

3、unordered_multimap

4、unordered_multiset

和上面的四个对应类似,就是key是无序储存的。

map的默认分配器是std::allocator<std::pair<const K,V>>。K是key类型,V是value类型

set的默认分配器是std::allocator<K>。

操作:

1、添加元素

insert向map中添加元素必须是std::pair

std::map
map2; map2.insert(std::make_pair(2,"xxx"));

或者这样写,隐式构造:

map2.insert({4,"xxxx"});

2、遍历元素

std::map
map2; map2.insert(std::make_pair(2,6.66)); map2.insert({4,8.88}); for(auto it = map2.begin();it != map2.end();++it) { qDebug()<
first<
second; }

3、删除元素,和顺序容器一样,用erase()元素,map的一个车载版本是erase(key):

std::map
map2; map2.insert(std::make_pair("www",6.66)); map2.insert({"qqqqq",8.88}); for(auto it = map2.begin();it != map2.end();++it) { qDebug()<
first<
second; } map2.erase("www"); for(auto it = map2.begin();it != map2.end();++it) { qDebug()<
first<
second; }

 

转载地址:http://tavx.baihongyu.com/

你可能感兴趣的文章
MySQL中DQL语言的执行顺序
查看>>
mysql中floor函数的作用是什么?
查看>>
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中json_extract的使用方法
查看>>
mysql中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>