是否可以在程序崩溃后执行代码?

Is it possible to execute code after a program has crashed?

本文关键字:执行 代码 崩溃 程序 是否      更新时间:2023-10-16

我希望能够在发生崩溃时从应用程序转储信息。 是否可以做一些事情,比如分配一个回调,在程序崩溃时调用? 回调将从应用程序转储数据。 转储的数据将是特定于应用程序的数据,可能位于堆栈转储中,但非程序员更容易读取。

操作系统是Windows 10。

程序崩溃后是否可以执行代码?

通常,根据操作系统的不同,进程将在终止之前从操作系统接收信号。信号处理程序(如果已注册并且信号未被屏蔽)有机会在进程终止之前执行代码。

终止后,进程不存在,无法执行代码,并且其内存不再可访问。

可以在信号处理程序中安全使用的功能是有限的。C++标准保证了以下功能的安全性(如果我错过了一些功能,可能并不详尽):

_Exit
abort
forward
initializer_list functions
memcpy
memmove
move
move_if_noexcept
numeric_limits members
quick_exit
signal
type traits
plain lock-free atomic operations

请注意,标准保证的任何功能都不能输出。您的操作系统也可能允许其他功能,并且应该有列出它们的文档。POSIX标准保证了openwrite功能的安全性,可用于输出。


以上假设崩溃的来源在程序之外(例如,用户请求从操作系统终止,或者您的进程访问无效内存并且操作系统对此做出反应)。如果崩溃的来源来自程序内部,特别是如果std::terminate是由您或标准库调用的,那么您可以改为注册一个std::terminate_handler,它不像信号处理程序那样受到限制。

Windows程序的一个可能的解决方案是使用MiniDumpWriteDump函数。 本页介绍在 Windows 中发生崩溃时编写小型转储的不同替代方法 - https://learn.microsoft.com/en-us/windows/desktop/dxtecharts/crash-dump-analysis