问题
System.InvalidCastException: 无法将类型为“System.__ComObject”的 COM 对象强制转换为接口类型“ACTPCCOMLib.IActFXCPU3”。此操作失败的原因是对 IID 为“{CEAA03A5-6C4A-11D5-9312-009099244EFD}”的接口的 COM 组件调用 QueryInterface 因以下错误而失败: 因为应用程序正在发送一个输入同步呼叫,所以无法执行传出的呼叫。 (异常来自 HRESULT:0x8001010D (RPC_E_CANTCALLOUT_ININPUTSYNCCALL))。
在 System.StubHelpers.StubHelpers.GetCOMIPFromRCW(Object objSrc, IntPtr pCPCMD, IntPtr& ppTarget, Boolean& pfNeedsRelease)
在 ACTPCCOMLib.IActFXCPU3.GetDevice(String szDevice, Int32& lplData)
在 RSS_ATDPS.BIZ.CPLC.getStateFlag(String qian, String DeviceX, Int32& alarmFlag)
环境
系统:Windows10
框架:.Net Framework 4.5
操作逻辑:将带有三菱PLC控件 PLCActiveXEnvironment3.0 的程序,使用的是串口,将程序加入到开机自启,每次电脑开机上述错误,重启软件后能正常运行。
分析
可能跟电脑性能和系统有关系,导致 自启软件 在 控件相关的服务程序启动之前先启动。
延伸分析
因为是.net的程序所以不能用depends.exe来查找依赖项,于是借鉴工具Windows SDK 自带反编译工具 ildasm.exe来分析
通过ildasm反编译运行程序找到 Interop.ACTPCCOMLi1b.dll 依赖的动态库 mscorlib.dll 中的 System.StubHelpers.StubHelpers.GetCOMIPFromRCW 函数。
通过 ildasm 反编译,查看 mscorlib.dll 相关函数。