运维开发网

c# – WinForms中的WPF:虽然UI线程处于活动状态,但在Dispatcher.Invoke上被阻止

运维开发网 https://www.qedev.com 2020-04-14 17:01 出处:网络 作者:运维开发网整理
我们在WinForms控件中嵌入了一个 WPF控件,该控件又作为ActiveX控件公开.此ActiveX最终用于由第三方开发的C应用程序. 在某些时候,ActiveX控件的UI变得冻结,而C应用程序的其余部分运行正常.经过一些调试后,我注意到每次调用Application.Current.Dispatcher.Invoke时都阻止了WPF控件.但是,WinForms控件处理它的Control.In
我们在WinForms控件中嵌入了一个 WPF控件,该控件又作为ActiveX控件公开.此ActiveX最终用于由第三方开发的C应用程序.

在某些时候,ActiveX控件的UI变得冻结,而C应用程序的其余部分运行正常.经过一些调试后,我注意到每次调用Application.Current.Dispatcher.Invoke时都阻止了WPF控件.但是,WinForms控件处理它的Control.Invoke调用就好了.每当我暂停调试器时,我都可以看到UI线程在C应用程序中做了一些工作,但似乎没有阻塞或等待任何事情.这就好像UI线程突然并且莫名其妙地拒绝执行WPF委托.

当C应用程序在很长一段时间(几分钟)内独占UI线程时,WPF控件有时会进入此状态.我要做的第一件事就是使用不同的线程进行这样一个耗时的任务,但正如我已经说过的,我不负责C应用程序正在做什么.无论如何,这不是我的WPF控件以这种方式运行的原因.我不知道如何解决这个问题;任何帮助,将不胜感激.

我建议运行MS Debug Diagnostics Tool – http://support.microsoft.com/kb/2580960.

我们已经有了很好的结果来识别COM互操作阻塞问题,在我们的例子中,这是一个挂起的COM终结器阻塞垃圾收集.您可以在各种模式下运行它,但是当使用.NET分析运行时,它将突出显示终结器队列等的任何问题.运行起来有点笨拙,但它给你的信息是黄金.

0

精彩评论

暂无评论...
验证码 换一张
取 消