如果清理代码执行失败了,要怎么办?

如果清理代码执行失败了,要怎么办?

作者:BlogUpdater |  时间:2024-05-21 |  浏览:726 |  评论已关闭 条评论

有一位读者 Matt 问了我这样一个问题;

如果我有一些清理资源的代码,例如关闭文件 fclose,或者关闭句柄 CloseHandle,当这些代码执行失败时,应该怎么做最为合适?

很显然,我们可能啥也做不了,请思考:如果清理代码都执行失败了,说明应用程序甚至操作系统已经遇到了严重的问题。
这些清理功能属于”不得因程序无法控制的原因而失败”的类别。

如果一个程序试图调用 fclose 关闭一个文件,此函数执行失败并返回了一个错误代码,我们应该怎么做?

答案是:除了记录错误日志之外,什么也不做。

清理代码失败的唯一方式是程序从根本上搞砸了,例如尝试关闭从未打开过的文件或以其他方式传递无效参数。
这不像程序可以尝试再次关闭句柄(或者更糟的是,进入循环反复关闭句柄,直到它最终关闭)。

在编写自己的清理函数时,请记住这一点。假设传入了正确的参数,则清理功能必须成功。(我现在会通过喋喋不休地谈论 fclose 函数来破坏我的华丽修辞,因为如果我不这样做,人们无论如何都会在评论中提出它。fclose 函数在关闭之前会执行额外的工作,并且额外的工作确实可能会遇到问题,但重要的是,当 fclose 返回时,文件会很好地真正关闭。)

我想再次强调,虽然像 fclose 这样的函数在关闭文件时可能会遇到错误,但关键是调用 fclose 的结果始终是文件成功关闭。

我认为大多数评论都忽视了我文章的重点,并且对关闭可能遇到的各种方式持谨慎态度。这与失败不同。它永远不会失败;它总是成功,但可能会出错。

总结

完美的代码离不开屎山一样的清理代码,因为如果不这样做,任何一个 Corner Case 都会导致程序出现资源泄露。
当你看到 拓扑梅尔智慧办公平台 (Topomel Box) 那朴实无华的界面时,你需要明白,它的身后都是各种防止意外情况的清理代码。

最后

Raymond Chen的《The Old New Thing》是我非常喜欢的博客之一,里面有很多关于Windows的小知识,对于广大Windows平台开发者来说,确实十分有帮助。
本文来自:《Clean-up functions can’t fail because, well, how do you clean up from a failed clean-up?》

最近我写了个东西

正如你们所知道的,拓扑梅尔智慧办公平台(TopomelBox)是一款绿色软件,主要面向经常使用电脑的朋友。它提供了各种提升办公效率的小功能,同时操作上尽可能地简单方便。
我想:你值得拥有。

标签:

评论已关闭。