C++拾趣——STL容器的插入、删除、遍历和查找操作性能对比(Windows VirtualStudio)——删除

栏目: C++ · 发布时间: 7年前

内容简介:vector性能是最差的。我们再看下其他容器deque和forward_list性能是最优的。由于vector的性能太差,上图例中没有将其列出来。

删除

头部删除

元素个数>15000

C++拾趣——STL容器的插入、删除、遍历和查找操作性能对比(Windows VirtualStudio)——删除
erase_begin_16384_highest

vector性能是最差的。我们再看下其他容器

C++拾趣——STL容器的插入、删除、遍历和查找操作性能对比(Windows VirtualStudio)——删除
erase_begin_16384

deque和forward_list性能是最优的。

元素个数<1024

C++拾趣——STL容器的插入、删除、遍历和查找操作性能对比(Windows VirtualStudio)——删除
erase_begin_1024

由于vector的性能太差,上图例中没有将其列出来。

我们可以观察到,各个容器在特别的元素个数时,会同步发生高耗时的操作。在图中就是各个曲线在某个x轴区间都发生了值快速递增。

结果对比:

vector的性能始终最差。

除了vector,非关联容器性能都优于关联容器。

除了vector,set和map的性能最差。

中间删除

元素个数>15000

C++拾趣——STL容器的插入、删除、遍历和查找操作性能对比(Windows VirtualStudio)——删除
erase_mid_16256_highest

vector的性能最差。我们看下其他容器

C++拾趣——STL容器的插入、删除、遍历和查找操作性能对比(Windows VirtualStudio)——删除
erase_mid_16256

效率最好的是list和forward_list。其他容器差不了太多,包括deque性能也不行。

元素个数<256

C++拾趣——STL容器的插入、删除、遍历和查找操作性能对比(Windows VirtualStudio)——删除
erase_mid_256_highest

和小容器插入表现的不同,vector在从中间删除元素时效率依旧糟糕。

结果对比:

vector效率持续糟糕。

list和forward_list性能最优。

deque和其他关联容器效率相似,比较低效。

尾部删除

元素个数>15000

C++拾趣——STL容器的插入、删除、遍历和查找操作性能对比(Windows VirtualStudio)——删除
erase_end_16384_highest

foward_list效率极差。我们再看下其他容器

C++拾趣——STL容器的插入、删除、遍历和查找操作性能对比(Windows VirtualStudio)——删除
erase_end_16384

vector表现最优。其次是deque和list。

map的性能要优于set。

set在元素个数超过3000左右后,效率仅优于forward_list。

结论:

vector只有在尾部删除时性能最优。在头部和中间删除时,性能始终是最差的。

forward_list在头部和中间删除时,性能是非常好的。但是在尾部删除时,性能极其差。

中间删除时,性能最高的是list和forward_list。deque在这个场景下表现很平庸,和其他关联容器差不多。

头部和尾部删除时,deque性能非常优异。

文中图例可从如下地址获取: https://github.com/f304646673/stl_perf/tree/master/windows


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

编程匠艺

编程匠艺

Pete Goodliffe / 韩江、陈玉 / 电子工业出版社 / 2011-11 / 85.00元

如果你可以编写出合格的代码,但是想更进一步、创作出组织良好而且易于理解的代码,并希望成为一名真正的编程专家或提高现有的职业技能,那么Pete Goodliffe编写的这本本书都会为你给出答案。本书的内容涵盖编程的各个要素,如代码风格、变量命名、错误处理和安全性等。此外,本书还对一些更广泛的编程问题进行了探讨,如有效的团队合作、开发过程和文档编写,等等。本书各章的末尾均提供一些思考问题,这些问题回顾......一起来看看 《编程匠艺》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具