一个程序进行sql操作,但是记录数太多,而且sql语句有复杂,就报了这样的错误(转):
异常信息:CLR无法从COM 上下文0x645e18 转换为COM上下文0x645f88,这种状态已持续60秒。拥有目标上下文/单元的线程很有可能执行的是非泵式等待或者在不发送 Windows 消息的情况下处理一个运行时间非常长的操作.这种情况通常会影响到性能,甚至可能导致应用程序不响应或者使用的内存随时间不断累积。要避免此问题,所有单线程单元(STA)线程都应使用泵式等待基元(如 CoWaitForMultipleHandles),并在运行时间很长的操作过程中定期发送消息
解决方法是 在Debug -> Exceptions -> Managed Debug Assistants里 去掉ContextSwitchDeadlock一项前面的钩。
在调试(菜单)-->异常--> Managed Debug Assistants里 去掉ContextSwitchDeadlock一项前面的钩。
CLR上下文切换死锁
本文介绍了一个关于CLR无法完成COM上下文切换的问题及其解决办法。该问题出现于执行长时间SQL操作时,导致应用程序可能变得无响应或内存使用量不断增加。解决方案涉及调整调试设置以禁用特定的调试助手。

被折叠的 条评论
为什么被折叠?



