一个分别使用std::list的remove和erase的问题

      在实际使用上一篇文章提到的基于策略的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)。结果困扰我一整天的问题也消失了……。

      虽然问题解决了,但是还不是很清楚究竟怎么回事,望牛人能够解答。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值