1、vector

变长一维数组,连续存放的内存块,有保留内存。堆中分配内存;

支持[]操作,高效率的随机訪问;

在最后添加元素时,一般不须要分配内存空间,速度快;在中间或開始操作元素时要进行内存拷贝效率低;

vector高效的原因在于配置了比其所容纳的元素很多其它的内存,内存又一次配置会花非常多时间。

注:须要高效的随即存取,而不在乎插入和删除使用vector。

2、list

双向链表,内存空间上可能是不连续的,无保留内存。堆中分配内存;

不支持随机存取。開始和结尾元素的訪问时间快,其他元素都O(n)。

在不论什么位置安插和删除元素速度都比較快。安插和删除操作不会使其它元素的各个pointer。reference,iterator失效;

注:大量的插入和删除。而不关系随即存取使用list。

3、deque

双端队列,在堆上分配内存,一个堆保存几个元素。而堆之间使用指针连接;

支持[]操作,在首端和末端插入和删除元素比較快,在中部插入和删除则比較慢。像是list和vector的结合;

注:关心插入和删除并关心随即存取折中使用deque。

4、set&multiset

有序集合,使用平衡二叉树存储。依照给定的排序规则(默认按less排序)对set中的数据进行排序;

set中不同意有反复元素。multiset中执行有反复元素;

两者不支持直接存取元素的操作;

由于是自己主动排序,查找元素速度比較快。

不能直接改变元素值。否则会打乱原本正确的顺序,必须先下删除旧元素,再插入新的元素。

5、map&multimap

字典库,一个值映射成还有一个值。使用平衡二叉树存储,依照给定的排序规则对map中的key值进行排序。

map中的key值不同意反复,multimap中的key同意反复。

依据已知的key值查找元素比較快;

插入和删除操作比較慢。

最新文章

  1. js封装包
  2. HBase Shell操作
  3. Python检验一个文件是否存在,如果不在就自己填写内容。
  4. JS练习题2共8题
  5. 10TSQL语言概述-脚本调试-命名规范-天轰穿数据库2014
  6. Json数据转换
  7. PHP学习笔记8-文件操作
  8. 整理自百度知道提问的几道Java编程题
  9. 数据类型&字符串得索引及切片
  10. gerrit代码简单备份方案分享
  11. Oracle11.2.0.1 升级Oracle11.2.0.4 后 listener 的端口改变需要处理
  12. 【SPOJ10628】Count on a tree
  13. 6-9-哈夫曼树(HuffmanTree)-树和二叉树-第6章-《数据结构》课本源码-严蔚敏吴伟民版
  14. 使用kill -9 进程ID杀死jps中进程
  15. Arduino从DHT11读取温湿度数据并显示在1602LCD
  16. 【Sikuli】Sikuli 文档
  17. DAC--解决windows验证无法登陆的问题
  18. WebDriver API 实例详解(一)
  19. Windows 64位操作系统下安装和配置MySQL
  20. java中length的用法

热门文章

  1. 第8章 MyBatis简介
  2. [源码管理] ubuntu下SVN服务器安装配置
  3. hammer教程
  4. 工厂方法模式(Product)C++实现
  5. meta标签的作用及整理
  6. [Offer收割]编程练习赛36
  7. MySQL 5.6 Reference Manual-14.2 InnoDB Concepts and Architecture
  8. 解决启动httpd报: apr_sockaddr_info_get() failed for错误
  9. 深入jar包:从jar包中读取资源文件
  10. win 2016 添加系统组件注册表,