检测到 ContextSwitchDeadlock 问题的解决办法

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

解决方法:如果出现这个提示,点击在调试菜单中的异常选项,在Managed Debugging Assistants 中将ContextSwitchDeadlock后面的第一个勾给去掉就可以了。

 

如果在试图进行 COM 上下文转换期间检测到一个死锁,则将激活 ContextSwitchDeadlock 托管调试助手 (MDA)。

Collapse 图像症状

最常见的症状是:从托管代码对非托管 COM 组件的调用未返回任何结果。另一个症状是内存使用量与时俱增。

Collapse 图像原因

原因很可能是单线程单元 (STA) 线程不发送消息。STA 线程或者等待而且不发送消息,或者执行一个长时间的操作而且不允许发送消息队列。

内存使用与时俱增的原因是:终结器线程试图对非托管 COM 组件调用 release 而该组件未返回任何结果。这会阻止终结器回收其他对象。

Collapse 图像解决办法

遵循有关 STA 消息发送的 COM 规则。

Collapse 图像对运行库的影响

此 MDA 对 CLR 无任何影响。它只报告有关 COM 上下文的数据。

Collapse 图像输出

一条描述当前上下文和目标上下文的消息。

Collapse 图像配置

 
<mdaConfig>
  <assistants>
    <contextSwitchDeadlock enable="false" />
  </assistants>
</mdaConfig>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值