关于WaitForSingleObject的问题!请帮帮忙看看,在线等!!

maomao2332 2003-12-15 08:52:26
我的程序,在执行>10000s时出现意外的错误,经过我的分析,发现是一个 WaitForSingleObject()出现了问题!请看:
Start=GetTickCount(); //DWORD
Now=GetTickCount(); //DWORD
while(((Now-Start)/1000)<(TotalTime*60)) //总的运行时间
{
double ff=FrequencyArray[i];

if(ff>0)
{
CWinThread* pChildThread=AfxBeginThread (Respond,&ff,SYNCHRONIZE|THREAD_PRIORITY_NORMAL,
0,CREATE_SUSPENDED,0);
pChildThread->ResumeThread();
DWORD result=WaitForSingleObject(pChildThread->m_hThread,INFINITE);
switch(result)
{
case WAIT_OBJECT_0:
str=" WAIT_OBJECT_0 ";
file.Write(str,str.GetLength());
break;
case WAIT_FAILED:
str=" WAIT_FAILED ";
file.Write(str,str.GetLength());
result=GetLastError();
str.Format("result=%ld",result);
file.Write(str,str.GetLength());
break;
default:
str.Format("result=%ld",result);
file.Write(str,str.GetLength());

}
i++;
i=i%LenOfFrequencyArray;
Now=GetTickCount();
}
结果发现file里面在时间>10000s的时候,应该有的关于result的结果纪录没有,但是它的处理函数Respond的结束纪录有!说明Respond正常的return了。也就是应该能够说明是WaitForSingleObject出错了,连返回的result值都没有。我这个程序是做数据采集用的。不知道什么情况下会导致这样的错误。
...全文
63 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
maomao2332 2003-12-15
  • 打赏
  • 举报
回复
错误的提示:
File:thrdcore.cpp
Line:113
我打开了这个文件:
DWORD nResult = 0;
if (pThread->m_pfnThreadProc != NULL)
{
nResult = (*pThread->m_pfnThreadProc)(pThread->m_pThreadParams);
ASSERT_VALID(pThread); <------------应该是113行之所在!
}
// else -- check for thread with message loop
else if (!pThread->InitInstance())
{
ASSERT_VALID(pThread);
nResult = pThread->ExitInstance();
}
else
{
// will stop after PostQuitMessage called
ASSERT_VALID(pThread);
nResult = pThread->Run();
}

// cleanup and shutdown the thread
threadWnd.Detach();
AfxEndThread(nResult);
maomao2332 2003-12-15
  • 打赏
  • 举报
回复
另外,我的系统平台是2000Pro.用的是VC6.0
maomao2332 2003-12-15
  • 打赏
  • 举报
回复
补充:以上某一句的原文应该是CWinThread* pChildThread=AfxBeginThread (Respond,&ff,THREAD_PRIORITY_NORMAL, 0,CREATE_SUSPENDED,0);我写错了!
因为看到msdn上提到了SYNCHRONIZE,我在想是不是应该把这个加上去,所以在楼上写错了。

16,471

社区成员

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

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

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