首页 后端开发 C#.Net教程 stl中的size的坑

stl中的size的坑

Nov 22, 2016 pm 03:12 PM
stl

去年刚进公司的时候,公司基础库里面有个LRUCache,里面的实现用的是std::list。但是里面计算std::list的函数直接使用的是stl里面的size()方法。结果压测的时候,性能卡在这里了。
今天,有个同事又在基础库里面发现一个队列的实现,也用到了std::list,取元素的个数的时候同样用到了size()方法。
很遗憾的是,公司的基础库只暴露了头文件,无法一一去检查这个坑是否会在其他地方还会有。

下面看一下stl里面size()方法的实现:

size_type    
  size() const
      { return std::distance(begin(), end()); }
登录后复制

上面的代码g++版本是4.2.1

显然,复杂度为O(N)。当list里面元素比较多的时候,计算将很慢。 所以,当使用std::list的时候,一定记得自己维护一个count。


本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何在 C++ STL 中实现定制的比较器? 如何在 C++ STL 中实现定制的比较器? Jun 05, 2024 am 11:50 AM

实现定制比较器可以通过创建一个类,重载运算符()来实现,该运算符接受两个参数并指示比较结果。例如,StringLengthComparator类通过比较字符串长度来排序字符串:创建一个类并重载运算符(),返回布尔值指示比较结果。在容器算法中使用定制比较器进行排序。通过定制比较器,我们可以根据自定义标准对数据进行排序或比较,即使需要使用自定义比较标准。

如何获取C++ STL容器的大小? 如何获取C++ STL容器的大小? Jun 05, 2024 pm 06:20 PM

通过使用容器的size()成员函数,可以获取容器中元素的数量。例如,vector容器的size()函数返回元素数量,list容器的size()函数返回元素数量,string容器的length()函数返回字符数量,deque容器的capacity()函数返回分配的内存块数量。

如何设计自定义的 STL 函数对象来提高代码的可重用性? 如何设计自定义的 STL 函数对象来提高代码的可重用性? Apr 25, 2024 pm 02:57 PM

使用STL函数对象可提高可重用性,包含以下步骤:定义函数对象接口(创建类并继承自std::unary_function或std::binary_function)重载operator()以定义函数行为在重载的operator()中实现所需的功能通过STL算法(如std::transform)使用函数对象

使用 C++ STL 时如何处理哈希冲突? 使用 C++ STL 时如何处理哈希冲突? Jun 01, 2024 am 11:06 AM

C++STL哈希冲突的处理方式有:链地址法:使用链表存储冲突元素,适用性好。开放寻址法:在桶中查找可用位置存储元素,子方法有:线性探测:按顺序查找下一个可用位置。二次探测:以二次方形式跳过位置进行查找。

如何利用 C++ STL 实现代码的可读性和维护性? 如何利用 C++ STL 实现代码的可读性和维护性? Jun 04, 2024 pm 06:08 PM

通过利用C++标准模板库(STL),我们可以提升代码的可读性和维护性:1.使用容器取代原始数组,提高类型安全性和内存管理;2.利用算法简化复杂任务,提高效率;3.使用迭代器增强遍历,简化代码;4.使用智能指针提升内存管理,减少内存泄漏和悬垂指针。

C++ STL容器中常见类型有哪些? C++ STL容器中常见类型有哪些? Jun 02, 2024 pm 02:11 PM

C++STL中最常见的容器类型分别是Vector、List、Deque、Set、Map、Stack和Queue。这些容器为不同的数据存储需求提供了解决方案,例如动态数组、双向链表和基于键和值的关联容器。实战中,我们可以使用STL容器高效地组织和访问数据,例如存储学生成绩。

如何排序C++ STL容器? 如何排序C++ STL容器? Jun 02, 2024 pm 08:22 PM

C++中对STL容器排序的方法:使用sort()函数,原地排序容器,如std::vector。使用有序容器std::set和std::map,元素在插入时自动排序。对于自定义排序顺序,可以使用自定义比较器类,如按字母顺序排序字符串向量。

C++ STL中的迭代器 C++ STL中的迭代器 Aug 21, 2023 pm 08:52 PM

C++STL(StandardTemplateLibrary)是C++程序语言的标准库之一,它包含了一系列的标准数据结构和算法。在STL中,迭代器(iterator)是一种非常重要的工具,用于在STL的容器中进行遍历和访问。迭代器是一个类似于指针的对象,它可以指向容器(例如vector、list、set、map等)中的某个元素,并可以在容器中进行移动、

See all articles