使用自定义删除器可确保文件句柄在智能指针销毁时自动安全释放,防止资源泄漏,结合std::unique_ptr实现RAII,提升代码安全与简洁性。

在C++中使用智能指针管理非内存资源,比如文件句柄,是一个良好实践。虽然
std::unique_ptr
std::shared_ptr
文件句柄是操作系统分配的有限资源,打开后必须显式关闭。如果使用裸指针或忘记关闭,容易造成资源泄漏。通过智能指针配合自定义删除器,可以在对象生命周期结束时自动调用
fclose()
std::unique_ptr
#include <memory>
#include <cstdio>
#include <iostream>
<p>// 自定义删除器:函数对象结构体
struct FileDeleter {
void operator()(FILE* file) const {
if (file) {
std::cout << "Closing file...\n";
fclose(file);
}
}
};</p><p>// 使用 unique_ptr 管理 FILE<em>
std::unique_ptr<FILE, FileDeleter> openFile(const char</em> filename) {
FILE* f = std::fopen(filename, "r");
if (!f) {
return nullptr; // 打开失败,返回空智能指针
}
return std::unique_ptr<FILE, FileDeleter>(f);
}</p>调用示例:
立即学习“C++免费学习笔记(深入)”;
int main() {
auto file = openFile("example.txt");
if (file) {
std::cout << "File opened successfully.\n";
// 使用文件指针,例如 fgetc(file.get())
} else {
std::cout << "Failed to open file.\n";
}
// 离开作用域时自动调用 FileDeleter::operator()
return 0;
}
如果不想定义结构体,可以用 lambda,但需注意类型推导问题。此时推荐使用
std::unique_ptr
auto makeFile(const char* filename) {
FILE* f = std::fopen(filename, "r");
if (!f) return std::unique_ptr<FILE, void(*)(FILE*)>(nullptr, [](FILE*){});
<pre class='brush:php;toolbar:false;'>return std::unique_ptr<FILE, void(*)(FILE*)>(
f,
[](FILE* f) {
if (f) fclose(f);
}
);}
这种写法使用函数指针作为删除器类型,支持 lambda 捕获为空的情况,适用于大多数场景。
FILE*
fclose
基本上就这些。用自定义删除器配合
std::unique_ptr
以上就是C++自定义删除器 文件句柄资源释放的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号