一个分别使用std::list的remove和erase的问题
来源:互联网 发布:java变量的命名规范 编辑:程序博客网 时间:2024/05/22 06:51
在实际使用上一篇文章提到的基于策略的Pool(http://blog.csdn.net/smuggler_2003/archive/2009/12/29/5099330.aspx)的时候,发现一个很妖怪的问题:在多次运行之后,可能会偶然崩溃。通过调试,发现总是中断在std::list中的remove函数
中的if (*_First == _Val) 处。
花了大量的精力去检查Pool的实现之后,仍旧毫无头绪。后来我将我原本的代码:
修改为
当时仅是考虑了性能问题,因为看std::list源代码的实现,remove其实是先遍历,再删除的,也就是说它的时间复杂度为O(n)。结果困扰我一整天的问题也消失了……。
虽然问题解决了,但是还不是很清楚究竟怎么回事,望牛人能够解答。
- 一个分别使用std::list的remove和erase的问题
- STL Vector remove()和erase()的使用
- STL Vector remove()和erase()的使用
- Vector remove()和erase()的使用
- STL Vector remove()和erase()的使用
- STL Vector remove()和erase()的使用
- STL Vector remove()和erase()的使用
- STL Vector remove()和erase()的使用
- STL Vector remove()和erase()的使用
- STL Vector remove()和erase()的使用
- STL Vector remove()和erase()的使用
- std::set, std::list, std::vector在erase的区别
- C++ list中erase和remove函数的用法
- C++ list中insert、erase和remove函数的用法
- std::vector的erase的问题
- list中的erase和remove
- 辨析std::vector::erase和std::remove (未完待续)
- STL remove 和 erase 的区别
- Symbian编程工程配置文件bld.inf、.mmp和.pkg文件结构浅析
- 网页数据抓取系统解决方案
- 经典图书《重构:改善既有代码的设计》图灵再版出版倒计时
- 浏览器的事件处理
- 被更改的通知
- 一个分别使用std::list的remove和erase的问题
- 图灵喜获Stevens名著《TCP/IP Illustrated》影印版权
- 设计模式学习----工厂方法模式
- 集群(Trunking)调度通信系统
- 差异在哪里?
- 配置tomcat ssi shtml
- 《水浒传》观后感
- 数字移动通信系统中广泛使用的两大类调制技术
- MySQL:日期函数、时间函数总结(MySQL 5.X)