Select the product you need help with
同步失败时调试文章编号: 173260 - 查看本文应用于的产品 症状在调试应用程序在 Windows NT 下的时,同步对象上等待的线程可能不会发布 (例如对于通过 PulseEvent() 或 SetEvent()/ResetEvent() 组合)。 原因解决方案放置 Sleep(0) 之前 PulseEvent() 或 SetEvent()/ResetEvent() 调用可能避开这一问题,但这并不保证任何一个。 遗憾的是,并不保证的解决此问题。 状态更多信息PulseEvent() 可能无法释放应用程序运行在调试环境中时,事件对象上等待的线程。这是无论使用调试信息编译代码,则返回 true。这也是的而不考虑是否执行调试对象由"转"命令或被"单个踩。 问题是如果多个线程正在等待该事件发生的可能性更大。未能释放等待线程变得更有可能仍如果有这些如 OutputDebugString() 所致的线程中发生的调试事件。放置 OutputDebugString() 直接之前 PulseEvent() 调用的调用是一种有效的方法的定期导致等待线程不在调试环境中唤醒。 由于 Win32 调试环境通常会挂起线程会发生这种情况。 发生这种情况时它将提取该线程的当前状态,使它在"挂起"的事件上等待。挂起此类在内部发生在每个调试事件。当恢复,线程回放入其以前的等待状态。如果线程是在调试挂起状态时,将出现在 PulseEvent(),该脉冲都将丢失该线程。这也是由应用程序使用 SuspendThread() 挂起线程的则返回 true。 此行为并不限于 PulseEvent()。等待线程是在其他方案为很好地包括一个快速 SetEvent()/ResetEvent() 对易受该"调试挂起"。 前面已提到此问题的一个可能的解决方法是将任何 PulseEvent() 或 SetEvent() 调用前的一个 Sleep(0) 调用。这可以解决该问题,在大多数的情况中,因为它使能够进行恢复可以开始再次等待的线程。 值得注意的是外部的调试环境不会发生此异常。 属性文章编号: 173260 - 最后修改: 2006年11月21日 - 修订: 4.5 这篇文章中的信息适用于:
机器翻译 注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。 点击这里察看该文章的英文版: 173260
(http://support.microsoft.com/kb/173260/en-us/
)
Microsoft和/或其各供应商对于为任何目的而在本服务器上发布的文件及有关图形所含信息的适用性,不作任何声明。 所有该等文件及有关图形均"依样"提供,而不带任何性质的保证。Microsoft和/或其各供应商特此声明,对所有与该等信息有关的保证和条件不负任何责任,该等保证和条件包括关于适销性、符合特定用途、所有权和非侵权的所有默示保证和条件。在任何情况下,在由于使用或运行本服务器上的信息所引起的或与该等使用或运行有关的诉讼中,Microsoft和/或其各供应商就因丧失使用、数据或利润所导致的任何特别的、间接的、衍生性的损害或任何因使用而丧失所导致的之损害、数据或利润不负任何责任。 |




回到顶端








