RAII的核心是将资源生命周期绑定到对象生命周期:构造时获取,析构时自动释放;C++智能指针(如std::unique_ptr、std::shared_ptr)是其典型实现,亦可扩展至文件、锁等任意资源管理。

RAII 的核心是把资源的生命周期绑定到对象的生命周期上:资源在构造时获取,在析构时自动释放。C++ 标准库中的智能指针(如 std::unique_ptr 和 std::shared_ptr)就是 RAII 的典型实现——它们在构造时接管原始指针,在离开作用域时自动调用 delete(或自定义删除器),无需手动干预。
std::unique_ptr 保证同一时间只有一个智能指针拥有该资源,移动后原指针变为空。它轻量、无开销,适合栈上对象替代动态分配。
auto ptr = std::make_unique<int>(42);</int>
ptr 被销毁时调用 delete,释放 int 所占内存std::unique_ptr<file decltype> file(fopen("log.txt", "w"), &fclose);</file>
std::shared_ptr 通过引用计数允许多个指针共享同一资源,最后一个 shared_ptr 析构时才释放资源。适用于需延长资源生命周期或跨函数/线程共享的场景。
std::make_shared 构造(更高效,一次分配控制块+对象):auto sp = std::make_shared<:vector>>(100);</:vector>
shared_ptr 相互持有,引用计数永不归零,可用 std::weak_ptr 打破循环智能指针是 RAII 的“现成工具”,但 RAII 本质是一种设计模式。任何需要配对操作的资源(文件、互斥锁、socket、数据库连接)都可封装为 RAII 类。
立即学习“C++免费学习笔记(深入)”;
std::mutex 的锁:std::lock_guard<:mutex></:mutex> 在构造时加锁,析构时自动解锁,即使异常发生也不遗漏一旦用智能指针管理某块内存,就不要再用原始指针保存其地址并手动 delete,否则会导致双重释放或悬空指针。
int* raw = new int(10); auto ptr = std::unique_ptr<int>(raw); delete raw;</int> → 重复释放ptr.release() 显式放弃所有权(仅在必要时)-Wdelete-non-virtual-dtor)和 ASan/UBSan 工具,及早发现资源管理问题以上就是C++如何实现RAII(资源获取即初始化)?(智能指针示例)的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号