意外的 IConnectionPointImpl::不建议调用 Windows Embedded Compact 7

Unexpected IConnectionPointImpl::Unadvise call on Windows Embedded Compact 7

本文关键字:Embedded Windows Compact 调用 IConnectionPointImpl 意外      更新时间:2023-10-16

我们在Win CE6上运行了一个更大的软件,没有问题。核心功能在提供连接点的 COM 服务器 DLL 中实现。COM 客户端程序在程序启动时为连接点注册事件处理程序,以获取状态通知等。在程序退出时,它通过调用相应的IConnectionPointImpl::Unadvise方法来注销处理程序。

现在,我们正在移植程序以在 Win EC 7 上运行。适用于 Win EC 7 的新主板支持包 (BSP( 运行良好。还有具有不同选项的不同版本,在不同的时间使用不同的Microsoft来源创建,但我们的软件始终显示相同的问题。

在程序启动时,启动后 ~10 秒,在所有注册的事件处理程序上意外调用IConnectionPointImpl::Unadvise。我们的源代码中只有一个调用IConnectionPointImpl::Unadvise的方法,这绝对不会执行。

问题出现~95%,但有时程序启动和运行没有问题。由于程序的大小,我们不能使用调试器,性能很差。

我们猜测,COM 运行时出于某些原因调用IConnectionPointImpl::Unadvise方法。但我们不知道如何防止这种情况。

有没有人观察到同样的问题?是否有可用的解决方案/解决方法?谢谢。

所以我们终于找到了解决这个问题的方法。

我们消除了对MarshalByReObject的依赖,并将其替换为ISerializable的正确实现。

这使我们能够在自定义 AppDomain 中正确加载我们的程序集和事件不再松散。

但这对加载程序集配置文件的路径有副作用。为了解决这个问题,我们还实现了一个AppDomain.AssemblyResolve事件,允许我们将加载重定向到适当的位置。

我希望这可以帮助您;)