effective STL课堂笔记1-----如何选择合适的容器

本文深入探讨了C++标准模板库(STL)中的容器类型及其适用场景。从序列容器到关联容器,再到非标准容器,文章详细阐述了如何根据具体需求选择最合适的容器,并提供了关键信息的总结。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先是容器分类:

 

   (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()。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值