gpt4 book ai didi

c# - 很奇怪——线程在读取 `dynamic` COM 对象的简单属性时挂起

转载 作者:太空宇宙 更新时间:2023-11-03 13:55:44 25 4
gpt4 key购买 nike

我有一个很奇怪的情况,我以前从未见过这样的事情。

我正在使用第三方应用程序的 COM 接口(interface)与程序进行通信。它是进程内 COM 服务器。我使用动态类型来访问目标应用程序的对象模型。

dynamic app = Activator.CreateInstance(Type.GetTypeFromProgID("SomeProgId"));

我用那个app反对获得其他dynamic应用程序的对象。其中一个对象代表相当大的数组,其中的元素具有许多属性。我遍历这个数组的所有元素,并读取它们的所有属性,即我在一个大循环中解析所述对象(执行几分钟)。

问题如下:有时,比如十次尝试中有一次,线程在读取其中一个属性(每次都不同)时“挂起”:

string someString = app.SomeArrayObject.Get(i).SomeStringProperty;

我是用后台worker做的,就卡在上面的assignment上了。快速说明:上面的语句是一行简化,实际上我一次访问对象的一个​​级别(“每个语句中只有一个点”),所以它实际上卡在阅读 SomeStringProperty 上属性(property)。不抛出异常或任何东西,只是无限期地挂起。我注意到 The thread '<No Name>' (0x1240) has exited with code 0 (0x0).消息在此之前发布在调试器的输出窗口中,因此我相信某些线程意外终止(尽管没有记录异常!)。当我中断调试时,调用堆栈实际上是无用的,因为它在这种情况下(在 COM 对象内)的使用非常有限。

我不知道为什么会这样,也不知道这怎么可能。读取简单字符串属性会导致永久挂起。你有什么想法吗?..

最佳答案

据透露,COM 服务器被注册为支持 MTA,但实际上仅为 STA 模式设计。该框架假定可以在 MTA 模式下使用它(因为注册表中的相应注册条目表明支持 MTA),并且可能会定期创建一些导致异常的后台线程。将线程的模式设置为 STA,或者在注册表中更改 COM 服务器的参数以报告 STA-only,解决了这个神秘的随机崩溃问题。

关于c# - 很奇怪——线程在读取 `dynamic` COM 对象的简单属性时挂起,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12263873/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com