熟悉模板和算法的大侠请教

jackyyefei 2003-08-19 05:16:18
不知为什么我下面的代码出错,不是一开始出错,而是运行一段时间后出错:

typedef list <CONNECTTHREAD> CONNECTTHREADLIST;
CONNECTTHREADLIST listConnectThread;
CONNECTTHREADLIST::iterator it;

for(it=listConnectThread.begin();it!=listConnectThread.end();it++)
if(it!=listConnectThread.end())
{
CONNECTTHREAD *conThread= (CONNECTTHREAD*)&(*it);
if (conThread->threadID==dwThreadID)//出错在这一句,说是访问越址
{

EnterCriticalSection(&csProtectList);
listUnusedThread.push_back((*it).hThread);
listConnectThread.erase(it);
LeaveCriticalSection(&csProtectList);
break;
}
}
我对模板不熟,请各位帮忙!我该如何解决这个问题?

谢谢
...全文
18 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
akun 2003-08-20
  • 打赏
  • 举报
回复
呵呵,我也是刚学stl...
CONNECTTHREADLIST listConnectThread 既然是多个线程操作的,他们的操作就应该要同步了....

对于iterator, 我现在都不是非常熟悉,要看stl原码分析那本书,呵呵。
jackyyefei 2003-08-20
  • 打赏
  • 举报
回复
To akun(疑无路):
你说的很有道理啊。
我也看来关于这么方面的书,那是不是可以这样说,对于list::iterator
必须在单独行动,如果有其他的iterator同时作删除或添加的时候,iterator 就失效呢?
因为我在其他的地方有线程push进去这个list里面。
有没有QQ啊
我的QQ是84931808,实时讨论好啊。
akun 2003-08-20
  • 打赏
  • 举报
回复
typedef list <CONNECTTHREAD> CONNECTTHREADLIST;
CONNECTTHREADLIST listConnectThread;
CONNECTTHREADLIST::iterator it;

for(it=listConnectThread.begin();it!=listConnectThread.end();it++)
if(it!=listConnectThread.end())
{
CONNECTTHREAD *conThread= (CONNECTTHREAD*)&(*it);
if (conThread->threadID==dwThreadID)//一个线程运行到这里。
{

EnterCriticalSection(&csProtectList);
listUnusedThread.push_back((*it).hThread);
listConnectThread.erase(it); //另一个线程刚刚运行完这一句。
LeaveCriticalSection(&csProtectList);
break;
}
}


jackyyefei 2003-08-20
  • 打赏
  • 举报
回复
已经同步了啊:
EnterCriticalSection(&csProtectList);

谁能帮我,我up
akun 2003-08-19
  • 打赏
  • 举报
回复
listConnectThread 是不是也需要线程同步的?
jackyyefei 2003-08-19
  • 打赏
  • 举报
回复
我debug了,conThread是有地址,不过地址是高端地址比如:0xdddddda。
就是这个地址指向了os专用的地址了,所以访问不允许。
但是我把conThread加入listConnectThread后,就没有其他的地方动它了,不应该
这样啊?
高手快来来啊,这是一个有意思的难题啊
碍踢工匠 2003-08-19
  • 打赏
  • 举报
回复
if(conThread)
{
if (conThread->threadID==dwThreadID)//出错在这一句,说是访问越址
....
}

加上一个判断试一下,可能是在某个Function创建CONNECTTHREAD对象
CONNECTTHREAD *conThread=new CONNECTTHREAD();
并Add到list,Function返回后,conThread所指向的mm给释放了,

有什么损失我不负责,哈
1.算法是程序的灵魂,优秀的程序在对海量数据处理时,依然保持高速计算,就需要高效的数据结构和算法支撑。2.网上数据结构和算法的课程不少,但存在两个问题:1)授课方式单一,大多是照着代码念一遍,数据结构和算法本身就比较难理解,对基础好的学员来说,还好一点,对基础不好的学生来说,基本上就是听天书了2)说是讲数据结构和算法,但大多是挂羊头卖狗肉,算法讲的很少。 本课程针对上述问题,有针对性的进行了升级 3)授课方式采用图解+算法游戏的方式,让课程生动有趣好理解 4)系统全面的讲解了数据结构和算法, 除常用数据结构和算法外,还包括程序员常用10大算法:二分查找算法(非递归)、分治算法、动态规划算法、KMP算法、贪心算法、普里姆算法、克鲁斯卡尔算法、迪杰斯特拉算法、弗洛伊德算法、马踏棋盘算法。可以解决面试遇到的最短路径、最小生成树、最小连通图、动态规划等问题及衍生出的面试题,让你秒杀其他面试小伙伴3.如果你不想永远都是代码工人,就需要花时间来研究下数据结构和算法。教程内容:本教程是使用Java来讲解数据结构和算法,考虑到数据结构和算法较难,授课采用图解加算法游戏的方式。内容包括: 稀疏数组、单向队列、环形队列、单向链表、双向链表、环形链表、约瑟夫问题、栈、前缀、中缀、后缀表达式、中缀表达式转换为后缀表达式、递归与回溯、迷宫问题、八皇后问题、算法的时间复杂度、冒泡排序、选择排序、插入排序、快速排序、归并排序、希尔排序、基数排序(桶排序)、堆排序、排序速度分析、二分查找、插值查找、斐波那契查找、散列、哈希表、二叉树、二叉树与数组转换、二叉排序树(BST)、AVL树、线索二叉树、赫夫曼树、赫夫曼编码、多路查找树(B树B+树和B*树)、图、图的DFS算法和BFS、程序员常用10大算法、二分查找算法(非递归)、分治算法、动态规划算法、KMP算法、贪心算法、普里姆算法、克鲁斯卡尔算法、迪杰斯特拉算法、弗洛伊德算法马踏棋盘算法。学习目标:通过学习,学员能掌握主流数据结构和算法的实现机制,开阔编程思路,提高优化程序的能力。

16,471

社区成员

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

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

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