检测到 ContextSwitchDeadlock

错误信息


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

引发错误的代码


该错误出现在文章:用Visual Studio 2010编写Data Url生成工具C#版
中的代码中。
关键代码行:

textBox1.Text = "<img src=\"data:image/" + ext + ";base64," + Convert.ToBase64String(ms.GetBuffer())  
                + "\" width=\"" + img.Width +"\" height=\"" + img.Height +"\" />";  

主要原因:
Convert.ToBase64String(ms.GetBuffer()) 返回的字符串过长。

半调子方法


调试》异常
这里写图片描述
找到ContextSwitchDeadlock,取消勾选,确定。
这里写图片描述
为什么说是半调子方法呢?
因为这不能根本的解决问题,而只是不再引发该异常了。
出现这样的问题肯定是程序本身有问题的,应该跟踪调试确定并解决问题的根本所在。

MSDN


contextSwitchDeadlock MDA
解决方法:遵循有关 STA 消息发送的 COM 规则。
说的太笼统,根本摸不着头脑。

stackoverflow


.NET - ContextSwitchDeadlock was detected
这里回答的很好!
这样就留下一个死窗口在用户桌面上,可不是绝佳的用户体验。并且它可能有副作用,从而导致其他程序变得反应迟钝,当他们将消息发送到顶层窗口。

你需要使用线程真正解决这一问题。看看 BackgroundWorker,可以在 MSDN 库和其他许多地方找到相关文档。

现在你明白了:为什么说是半调子方法呢?

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值