vector list deque map 的优缺点以及区别

以下内存均取自网络。

STL容器,大致分为以下三大类:

序列容器:vector、list、deque、string

关联容器:set、multiset、map、mulmap、hash_set、hash_map、hash_multiset、hash_mulmap

常用的大概只有vector list map set string 

下边是几个常用的容器的一些特性的记录,以备所需之时查看。


vector 

向量 相当于一个数组。在内存中分配一块连续的内存空间进行存储,支持补丁大小的存储。当超过已分配的空间是,会整体重新分配一块内存进行存储。
优点
1、不指定一块连续内存进行存储,可以像数组一样操作。
2、随机访问方便,支持下标访问和vector.at()操作。
3、节省空间。
缺点
1、在内部进行插入删除,效率较低。
2、只能在末端进行pop和push。

3、当动态长度超过默认分配大小后,要整体重新分配、拷贝和施放。


list

双向链表。每个结点都包含一个信息块Info、一个前驱指针Pre和一个后驱指针Post。可不比分配必须的大小,方便的进行插入删除操作。使用的是非连续的 内存空间进行存储。

优点

1、不适用连续内存完成动态操作。

2、在内部方便进行插入删除操作。

3、可在两端进行push和pop操作。

缺点

1、不支持随机访问,即下标操作和.at()。

2、相对于vector占用内存多。


deque

双向队列,在功能上合并了vector和list。

优点

1、支持随机访问。

2、可以再两端进行push和pop操作。

3、在内部方便进行插入和删除操作。

缺点

占用内存较多。


map

映照容器 元素数据是一个键值和一个映照数据组成。键值和数据之间有一一映照的关系。

map采用红黑树实现,插入的键值不能重复,比较函数只对元素的键值进行比较。元素的各项数据可通过键值索引出来。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值