【发布时间】:2013-03-13 12:15:09
【问题描述】:
我的 Delphi 应用程序(使用 XE3)需要处理移除 USB 串行端口时发生的 EInOutError 异常。该应用程序在测试环境中使用,因此不能依赖操作员单击“确定”按钮来关闭“应用程序错误”对话框。
我尝试了以下方法:
“try ..except”方法 - 这不会捕获这些异常。我认为这不起作用,因为异常不是由“try”块中的代码引起的。这似乎是一个较低级别的“系统级”异常。
我尝试将“ApplicationEvents”组件添加到我的表单中。 OnException 方法会捕获我的应用程序生成的“自定义”异常,但不会捕获系统级异常。
我还尝试添加一个全局异常挂钩(如Is it possible to have a global exception hook? 中所述)。这部分有效 - 它允许我在应用程序错误对话框之前执行操作,但不会停止错误对话框。
我会很感激任何想法!
【问题讨论】:
-
如果 try-except 块没有捕捉到异常,那么要么异常没有在你认为的地方发生,它在你尝试之前被其他代码捕捉和处理抓住它,或者它不是真正的例外。既然抓不到,怎么知道是EInOutError异常?
-
当 USB-Serial 被移除时,您是否会收到带有 DBT_DEVICEREMOVECOMPLETE 类型和 DBT_DEVTYP_PORT 设备类型的消息 WM_DEVICECHANGE?
-
嗨,Rob,我弹出一个标题为“应用程序错误”的对话框。对话框内的消息是“001C7052 模块 Project1.exe 中的异常 EInOutError”。这是在 IDE/调试器之外运行应用程序。
-
当对话框出现时,暂停程序的执行。查看当前线程的调用堆栈。您可以使用它来确定哪个线程正在显示对话框以及导致它的代码路径。确保您的异常处理程序位于该代码路径上。
-
@RobKennedy 谢谢 - 调用堆栈指出了问题的解决方案。当端口被移除时,AsyncPro Com Port 组件调用一个 ThreadGone 函数。这会调用一个引发 FileIO 错误的 CheckException 函数。最简单的解决方案似乎是修改组件源以根据需要处理此错误。