首先是容器分类:
(1)标准STL序列容器:vector、string、deque和list。
(2)标准STL关联容器:set、multiset、map和multimap。
(3)非标准序列容器slist和rope。slist是一个单向链表,rope本质上是一个重型字符串。
(4)非标准关联容器hash_set、hash_multiset、hash_map和hash_multimap。
接着如何选择更加合适的容器:
(1)如果希望可以在容器的任意位置插入一个新元素,那么选择序列容器会更合适。
(2)如果我们介意元素在容器中的顺序,那么要避免使用散列容器。
(3)如果希望可以随机访问迭代器,那么在技术层面上来说只能限于vector、deque和string。
(4)如果我们在意查找速度,那么我们首先应该考虑使用散列容器,然后是排序的vector以及标准的关联容器。
(5)如果我们介意容器的底层使用引用计数的话,我们尽量避开使用它,它的底层实现就是用引用计数来实现的。
我们可以考虑用vector<char>来代替string。
(6)如果需要支持多元素插入的话,这个时候就应该选择list,因为list是唯一提供多元素插入事务性语义的标准容器。
(7)如果需要具有有以下特性的序列容器:1)可以使用随机访问迭代器;2)只要没有删除而且插入只发生在容器结尾,指针和引用的数据就不会失效,那么这个时候deque是理想的选择。
它与vector对比,deque还支持从开始端插入数据:push_front()。
分享到:
相关推荐
Finix的精版Effective STL读书笔记
Effective STL Effective STL Effective STL Effective STL
STL源码剖析--教程精华STL源码剖析--教程精华STL源码剖析--教程精华STL源码剖析--教程精华STL源码剖析--教程精华STL源码剖析--教程精华STL源码剖析--教程精华
STL源码剖析--侯捷,STL源码剖析--侯捷STL源码剖析--侯捷STL源码剖析--侯捷STL源码剖析--侯捷
24-Effective STL中文版-245
关于Effective STL的读后感,还有一些此间想得东西和解决的问题
Effective STL 中文版.pdf
title: STL源码剖析-容器-slist- 笔记description: slist也就是single linked list(单向链表)。slist与l
经典的Effective STL教程,介绍STL的用法
Effective STL中文版.pdf 带目录书签 清晰版
[COM本质论].STL源码剖析--侯捷.pdf [COM本质论].STL源码剖析--侯捷.pdf [COM本质论].STL源码剖析--侯捷.pdf [COM本质论].STL源码剖析--侯捷.pdf
STL源码剖析--侯捷_繁体转简体中文文字版STL源码剖析--侯捷_繁体转简体中文文字版STL源码剖析--侯捷_繁体转简体中文文字版STL源码剖析--侯捷_繁体转简体中文文字版STL源码剖析--侯捷_繁体转简体中文文字版STL源码...
Effective.STL关于C++的开发,STL模版应用,STL模版应用,STL模版应用,STL模版应用
effective STL,学习C++ stl必备的资料,绝对让你对STL有一个新的认识!
effective stl 中英 清晰带目录
三十分钟掌握STL三十分钟掌握STL三十分钟掌握STL三十分钟掌握STL三十分钟掌握STL三十分钟掌握STL三十分钟掌握STL
STL源码剖析--侯捷_繁体和简体版集合