`
sealbird
  • 浏览: 572269 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

泵式等待 检测到 ContextSwitchDeadlock

阅读更多
在操作数据的时候,运行超出60秒出现的错误。
在baidu搜索到如下信息:
在vs 2005运行,不确定的出现这个提示
检测到 ContextSwitchDeadlock
Message: CLR 无法从 COM 上下文 0x1a3008 转换为 COM 上下文 0x1a3178,这种状态已持续 60 秒。拥有目标上下文/单元的线程很有可能执行的是非泵式等待或者在不发送 Windows 消息的情况下处理一个运行时间非常长的操作。这种情况通常会影响到性能,甚至可能导致应用程序不响应或者使用的内存随时间不断累积。要避免此问题,所有单线程单元(STA)线程都应使用泵式等待基元(如 CoWaitForMultipleHandles),并在运行时间很长的操作过程中定期发送消息。

有的时候出现,不是总出现。

请问是怎么回事呢?我没有用多线程。

谢谢大家指点

长时间执行的操作如何使程序不停止响应

以下是调试模式报出的异常
CLR 无法从 COM 上下文 0x1b1c38 转换为 COM 上下文 0x1b1da8,这种状态已持续 60 秒。拥有目标上下文/单元的线程很有可能执行的是非泵式等待或者在不发送 Windows 消息的情况下处理一个运行时间非常长的操作。这种情况通常会影响到性能,甚至可能导致应用程序不响应或者使用的内存随时间不断累积。要避免此问题,所有单线程单元(STA)线程都应使用泵式等待基元(如 CoWaitForMultipleHandles),并在运行时间很长的操作过程中定期发送消息。
有兴趣的可以看看这里的解答http://www.usdprofits.com/-t175147.htm

不过,没有太好的解决方法。很多都用多线程去处理!各位大侠有没有碰到这种问题,不知道还有没有其它解决方案!


===================================
VS.NET的调试菜单下选异常,把“Managed Debugging Assistants”下的“ContextSwitchDeadlock”后面的引发选项取消,重新进行调试,问题应该解决。
===================================
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics