STL list缓存队列管理的问题

partime 2005-06-12 03:50:06
typedef class CMyObject
{
DWORD m_dwLiveTime;
........
}MYOBJECT,*PMYOBJECT;
typedef list<PMYOBJECT> MYOBJECTLIST;
typedef list<PMYOBJECT>::iterator myIter;

MYOBJECTLIST MyCacheObjects;



myIter endIter=MyCacheObjects.end();
for(myIter iter=MyCacheObjects.begin();iter!=enditer;iter++)
{
PMYOBJECT pMyObject=*iter;
pMyObject->m_dwLiveTime++;
if(pMyObject->m_dwLiveTime >= dwPresetTimeOut)
{
MyCacheObjects.remove(iter);
delete pMyObject;
}
}

以上代码为什么执行删除一节点后就异常.
该如何解决?
...全文
80 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
partime 2005-06-13
  • 打赏
  • 举报
回复
哦?
iter = MyCacheObjects.erase(iter);
这样也行啊?
谢谢,赫赫
oyljerry 2005-06-12
  • 打赏
  • 举报
回复
iter = MyCacheObjects.erase(iter);
zengwujun 2005-06-12
  • 打赏
  • 举报
回复
我不是给了你代码吗,测试通过的,肯定没问题。

在list中,移除操作是常量时间度,很快的,remove和erase没有区别。
partime 2005-06-12
  • 打赏
  • 举报
回复
或者应该
tempiter = ++iter;
++i和i++的问题?
partime 2005-06-12
  • 打赏
  • 举报
回复
我这样写
myIter iter=MyCacheObjects.begin();
myIter tempIter;
while(iter!=endIter)
{
MYOBJECT *pMyObject=*iter;
pMyObject->m_dwLiveTime++;
if(pMyObject->m_dwLiveTime >= dwPresetTimeOut)
{
tempIter = iter++;
MyCacheObjects.erase(iter);
iter=tempIter;
delete pMyObject;
}
else
iter++;
}



可是也不行,照样出错.
partime 2005-06-12
  • 打赏
  • 举报
回复
remove又会启动另一个遍历循环,在队列较大时,效率比erase(iter)低吧?
有没有更好的方法?
zengwujun 2005-06-12
  • 打赏
  • 举报
回复
for(myIter iter=MyCacheObjects.begin();iter!=endIter;)
{
MYOBJECT *pMyObject=*iter;
pMyObject->m_dwLiveTime++;
if(pMyObject->m_dwLiveTime >= dwPresetTimeOut)
{
iter++;
MyCacheObjects.remove(pMyObject);
delete pMyObject;
}
else
iter++;
}

在list中,调用remove会使iter失效,你再让iter++就会出错.
首先让iter指向待移除元素的后一个,此后remove就可以了
sungengyu 2005-06-12
  • 打赏
  • 举报
回复
void remove(const _Ty& _V)
{iterator _L = end();
for (iterator _F = begin(); _F != _L; )
if (*_F == _V)
erase(_F++);
else
++_F; }
内容概要:本文深入讲解了C++ STLlist与deque两种容器的核心特性、应用场景及实战技巧。详细介绍了list基于双向链表的结构特点,强调其在频繁插入删除操作中的高效性,以及随机访问性能较差的局限;同时阐述了deque作为双端队列,在两端插入删除操作上的优势及其近似随机访问能力。文章通过代码示例展示了两类容器的常用成员函数,并对比了它们在队列与栈实现中的应用。进一步探讨了list与deque的迭代器特性、容器间数据转换方法以及与STL算法的结合使用,最后通过一个任务调度系统的实战项目,演示了如何利用list和deque实现任务的优先级管理、增删查改和调度逻辑,并提出了针对性能瓶颈的优化策略。 适合人群:具备C++基础语法知识,熟悉STL基本概念,有一定编程经验的初、中级开发者,尤其是正在学习数据结构与算法或准备提升实际编程能力的程序员。 使用场景及目标:①理解list和deque在不同操作下的时间复杂度差异及适用场景;②掌握如何根据实际需求选择合适的STL容器;③学会将STL容器应用于真实项目中,如任务调度、缓存管理等;④提升对迭代器、算法适配和性能优化的理解与实践能力。 阅读建议:此资源以理论结合代码实践的方式展开,建议读者在阅读过程中动手运行并调试文中示例代码,深入理解每种容器的行为特征。对于任务调度系统部分,可尝试扩展功能(如支持动态优先级调整、多线程任务处理等),以加深对容器特性的掌握和工程应用能力。

16,551

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧