gpt4 book ai didi

c++ - 程序崩溃时如何释放资源

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

我有一个使用他人服务的程序。如果程序崩溃,关闭这些服务的最佳方法是什么?在服务器端,我会定义一些检查器来监视客户端是否定期无效。但是我们可以在客户端做任何事情吗?我不确定正常的 RAII 在这种情况下是否仍然有效。我的代码是用 C 和 C++ 编写的。

最佳答案

如果您的应用程序遇到硬崩溃,那么不,您精心设计的清理代码将不会运行,无论它是 RAII 范例的一部分还是您在 main 末尾调用的方法。在导致应用程序终止的崩溃之后,应用程序的清理代码都不会运行。

当然,对于异常情况并非如此。尽管这些最终可能导致应用程序终止,但它们仍然以受控方式触发此终止。通常,运行时库会捕获未处理的异常并触发终止。在此过程中,将执行基于 RAII 的清理代码,除非它也抛出异常。然后你又回到了被毫不客气地从内存中剔除的状态。

但即使您的应用程序清理代码无法运行,操作系统仍会尝试在您之后进行清理。这解决了未释放的内存、句柄和其他系统对象的问题。一般来说,如果你崩溃了,你不用担心释放这些东西。您的应用程序的状态是不一致的,因此尝试执行一堆清理代码只会导致不可预测和潜在的错误行为,更不用说浪费大量时间了。只是崩溃,让系统处理你的烂摊子。 As Raymond Chen puts it :

The building is being demolished. Don't bother sweeping the floor and emptying the trash cans and erasing the whiteboards. And don't line up at the exit to the building so everybody can move their in/out magnet to out. All you're doing is making the demolition team wait for you to finish these pointless housecleaning tasks.

做你必须做的;跳过其他一切。

这种方法的唯一问题是,正如您在这个问题中所建议的那样,当您管理不受操作系统控制的资源时,例如另一个系统上的远程资源。在那种情况下,您几乎无能为力。 最佳 方案是让您的应用程序尽可能健壮,以免崩溃,但即使那样也不是完美的解决方案。考虑一下断电时会发生什么,例如因为用户的猫从墙上拉了电源线。那时不可能运行任何清理代码,因此即使您的应用程序永远不会崩溃,也可能会出现您无法控制的终止事件。因此,您的外部资源必须在发生故障时是可靠的。超时是一种标准方法,也是比轮询更好的解决方案。

根据特定用例,另一种可能的解决方案是在应用程序初始化时运行一致性检查和清理代码。这可能是您为旨在连续运行并在终止后立即重新启动的服务所做的事情。下次重新启动时,它会检查其数据和/或外部资源的一致性,根据需要释放和/或重新初始化它们,然后照常继续。显然,这对于典型的应用程序来说是一个糟糕的解决方案,因为无法保证用户会及时重新启动它。

关于c++ - 程序崩溃时如何释放资源,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40937292/

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