注销系统 出现 “程序正在结束,请稍候”框的原因

花花呀123456 2009-08-19 05:34:32
我在一个程序中处理WM_ENDSESSION消息,当系统要关机或者注销的时候,在里面做些清理工作。但是我发现,有时候注销,会出现一个跟程序卡死,手动去任务管理器去关一样的框,“程序正在结束,请稍候” 的框,可以点击确定,或者取消。这是一个随机出现的bug,当出现这个框的时候,如果马上消失,不需要手动取点这个框,那么就可以正常做清理工作,否则,程序不能收到WM_ENDSESSION消息,不能正常做清理工作。这是什么原因???


一般程序出现这种情况是由于什么原因,请教高手。
...全文
96 点赞 收藏 10
写回复
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
MoXiaoRab 2009-08-20
有工作线程正在被使用,出于安全的考虑,操作系统不去强制关闭它,而是等待它的终结,直到线程返回一个安全退出码。所以就出现了这种情况
回复
oyljerry 2009-08-20
多打印一些你退出时的调试信息log等,然后看出问题时,可能什么阻塞了...
回复
花花呀123456 2009-08-20
清理的时候调用了一个DLL A的函数,这个DLL A里面又调用的另外一个DLL B的函数,并且卸载了DLL B。
回复
lygfqy 2009-08-20
是不是程序清理中有些调用和系统相关
思考:系统的某些功用已经失去,而你还需要调用,而你的程序无法响应消息回应则导致系统无法关闭
仔细检查一下清理的过程,或者用排除法测试一下
回复
jason176374 2009-08-20
WM_ENDSESSION这个消息我处理过的,要注意返回值的意义。
而且要确保在一定时间内将该消息处理完,否则就有可能出现你说的问题。

但是具体的东西,由于时间久远,我忘记了。查查MSDN对该消息的说明吧
回复
花花呀123456 2009-08-20
昨天晚上写了一个自动测试的程序,就是让它不断的重启关机开机,结果到第120次重启之后,就出现了两个框。

第一个框: Socket Notification Sink:aa.exe---应用程序错误
“ox7c93190"引用的"0x00000000"内存不能为"read"

第二个框: 结束程序--aaWindow
因为正在等您响应,系统无法结束该程序


其中:aa.exe是我的程序,aaWindow是我的一个窗口

另外,从日志中可以看到,即使出现了结束框,但是清理工作正常进行。
回复
花花呀123456 2009-08-20
模拟什么消息呢?模拟WM_ENDSESSION???
回复
zgl7903 2009-08-19
可以模拟给自己的程序发送消息 然后调试
回复
jameshooo 2009-08-19
这个应该不是你的代码问题,而是其它某个应用或者服务的问题。由于它的不响应,导致系统直接终止后续的消息广播。碰巧这个应用在你的前面收到此消息。
回复
雪影 2009-08-19
mark
等待高手
回复
发动态
发帖子
VC/MFC
创建于2007-09-28

1.5w+

社区成员

VC/MFC相关问题讨论
申请成为版主
社区公告
暂无公告