Visual Studio 2005 长时间执行某操作引发错误的解决

今天在对数据库(环境:VS2005+SQL2005)进行多年的数据操作时出现了报出一个错误:

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

在微软的网站(http://msdn2.microsoft.com/zh-cn/library/ms172233(VS.80).aspx)找到一个解决方案,即在

配置文件中添加

<mdaConfig>
  <assistants>
    <contextSwitchDeadlock enable="false" />
  </assistants>
</mdaConfig>

没料到原来可执行的代码出了问题,在执行SqlConnection conn = new SqlConnection();时,引发错误:
“System.Data.SqlClient.SqlConnection”的类型初始值设定项引发异常。

把添加到配置文件的内容删除又恢复正常。但第一个异常仍没解决,最后找到一个解决办法即在Visual Studio 2005 的菜单中,找到

调试 → 异常,在弹出的取消勾选 ContextSwitchDeadlock 的 throw 项就OK了。这对需要长时间执行的程序报出的错误都可解决。

 来源:http://blog.csdn.net/hiyavip/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值