自定义删除器是智能指针中用于替代默认delete的可调用对象,能正确释放文件句柄、套接字等系统资源。它可作为std::unique_ptr和std::shared_ptr的模板参数或构造函数参数,指定如fclose、close等清理函数。例如用struct或lambda定义删除器,管理FILE*时自动调用fclose;同样适用于POSIX文件描述符、动态库句柄及互斥锁等资源。注意删除器类型影响智能指针类型,应轻量且noexcept,非指针资源宜用shared_ptr配空指针和删除器。自定义删除器是实现RAII和防止资源泄漏的关键机制。

在C++中,使用智能指针管理资源时,有时需要管理的不是普通堆内存,而是文件句柄、套接字、互斥锁等系统资源。这些资源无法通过普通的
delete
fclose
close
pthread_mutex_destroy
自定义删除器是一个可调用对象(函数指针、lambda、函数对象等),它替代智能指针默认的
delete
std::unique_ptr
std::shared_ptr
std::unique_ptr
#include <memory>
#include <cstdio>
<p>// 定义删除器结构体
struct FileDeleter {
void operator()(FILE* fp) const {
if (fp) {
std::fclose(fp);
}
}
};</p><p>// 使用 unique_ptr 管理文件
std::unique_ptr<FILE, FileDeleter> open_file(const char<em> path) {
FILE</em> fp = std::fopen(path, "r");
if (!fp) {
return nullptr;
}
return std::unique_ptr<FILE, FileDeleter>(fp);
}
也可以使用 lambda 配合
std::function
auto deleter = [](FILE* fp) {
if (fp) std::fclose(fp);
};
std::unique_ptr<FILE, decltype(deleter)> file_ptr(std::fopen("test.txt", "r"), deleter);
std::shared_ptr
auto file_shared = std::shared_ptr<FILE>(
std::fopen("data.txt", "r"),
[](FILE* fp) { if (fp) std::fclose(fp); }
);
只要引用计数归零,lambda 删除器就会被调用,确保文件正确关闭。
自定义删除器不仅适用于文件,也适用于各种需要特殊释放方式的资源:
auto fd_deleter = [](int fd) {
if (fd >= 0) ::close(fd);
};
std::unique_ptr<int, decltype(fd_deleter)> fd_ptr(new int(socket(AF_INET, SOCK_STREAM, 0)), fd_deleter);
// 注意:这里包装的是指针,实际更推荐用封装类或直接 RAII 包装
auto lib_deleter = [](void* handle) {
if (handle) dlclose(handle);
};
std::shared_ptr<void> lib(dlopen("libsample.so", RTLD_LAZY), lib_deleter);
例如,
pthread_mutex_t
pthread_mutex_destroy
使用自定义删除器时注意以下几点:
unique_ptr<T, D1>
unique_ptr<T, D2>
shared_ptr
基本上就这些。自定义删除器是实现资源安全释放的关键机制,配合智能指针能有效避免资源泄漏。只要设计好删除逻辑,任何需要手动释放的资源都可以被自动管理。不复杂但容易忽略。
以上就是自定义删除器怎么用 文件句柄等资源释放方案的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号