gpt4 book ai didi

c# - ActiveX DLL 锁定主 UI 线程

转载 作者:太空狗 更新时间:2023-10-29 23:20:14 25 4
gpt4 key购买 nike

我正在努力在 C# WinForms 应用程序的后台线程中运行来自 ActiveX DLL(从 VB6 编译)的函数。

因为 VB6 DLL 项目包含很多对名为 Sheridan Controls (threed32.ocx) 的旧库的引用,我被告知“不支持多线程模式”,我必须设置线程模型选项在 VB6 中编译 DLL 时改为单线程(而不是单元线程)。因此,即使我在调用 DLL 的 C# Thread 对象上将 ApartmentState 属性设置为 STA,它仍然会阻塞 UI 线程。

我不确定此时我的选择是什么。从 DLL 重构 Sheridan 控件将是一项乏味的工作。另一种是认输,让 UI 挂起,而 DLL 继续工作。

我想我的主要问题是;有谁知道我可以(没有太多麻烦)在可以从主 C# 线程异步调用的单独进程/服务中运行单线程 ActiveX DLL 的方法吗?或者还有其他我不知道的选项吗?

已解决:根据用户@mnistic 提供的信息,我找到了解决方案。我必须将 ActiveX DLL 重建为 ActiveX EXE,它作为进程外组件运行。为了让它工作,我必须在项目属性中将“启动模式”设置为“独立”。我还将 VB6 类上的 Instancing 参数设置为 SingleUse,以确保全局状态不会跨实例共享。

更新项目引用后,我能够从我的 C# 应用程序的后台线程中调用库中的函数,而不会导致 GUI 滞后。

最佳答案

在谈到 ActiveX 时,Microsoft 区分了进程内组件和进程外组件。有时,当人们谈论 ActiveX 时,他们指的是进程内组件、dll 或 ocx 文件,这些文件与使用它们的客户端在同一进程中运行。通常,这些组件包括 GUI 元素,VB6 使这些元素易于嵌入到客户端应用程序中。但是,进程内组件必须使用客户端的执行线程,在您的情况下,这会导致主线程中的感知锁定。

这就是进程外组件的用途。它们在单独的线程中执行——事实上是单独的进程。缺点是通信需要跨越进程边界,但在您的情况下这不是问题,而且它们相对容易设置:https://msdn.microsoft.com/en-us/library/aa262334%28v=vs.60%29.aspx

关于c# - ActiveX DLL 锁定主 UI 线程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47264054/

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