智能指针通过RAII机制确保异常安全,资源在析构时自动释放;2. std::unique_ptr用于独占资源,离开作用域即释放;3. std::shared_ptr通过引用计数管理共享资源,异常时引用归零自动回收;4. 避免手动管理,使用智能指针可防止内存泄漏。

在C++异常处理中,使用智能指针管理资源能有效避免内存泄漏,确保异常发生时资源也能被正确释放。核心在于:智能指针在析构时自动释放所管理的资源,而异常发生时局部对象的析构函数会被自动调用(RAII机制)。因此,只要把资源交给智能指针管理,就能实现异常安全。
std::unique_ptr适用于独占所有权的动态资源,它在离开作用域时自动删除所指向的对象。
例如,在可能抛出异常的函数中分配内存:
#include <memory>
#include <stdexcept>
<p>void riskyFunction() {
auto ptr = std::make_unique<int>(42); // 资源由unique_ptr管理</p><pre class='brush:php;toolbar:false;'>if (/* 某些条件 */) {
throw std::runtime_error("出错了!");
}
// 正常执行到这里,ptr仍会被自动释放}
立即学习“C++免费学习笔记(深入)”;
即使抛出异常,ptr 作为局部对象会被栈展开(stack unwinding)机制调用析构函数,自动释放new出的int。
当多个部分可能同时引用同一资源时,std::shared_ptr通过引用计数管理资源生命周期。
示例:
#include <memory>
#include <vector>
<p>std::shared_ptr<std::vector<int>> createAndProcess() {
auto vec = std::make_shared<std::vector<int>>(1000); // 大对象</p><pre class='brush:php;toolbar:false;'>vec->at(500) = 10; // 可能越界抛出异常
return vec; // 返回增加引用计数}
立即学习“C++免费学习笔记(深入)”;
如果 at() 抛出异常,vec 在函数退出时析构,引用计数减为0,vector内存自动释放,不会泄漏。
传统写法容易出错:
void badExample() {
int* p = new int(10);
if (condition) {
delete p;
throw std::exception();
}
delete p; // 如果上面抛出,这句不会执行
}
使用智能指针后,无需在catch块中手动释放:
void goodExample() {
auto p = std::make_unique<int>(10);
if (condition) {
throw std::exception(); // p会自动清理
}
}
基本上就这些。只要资源交给智能指针,不管函数正常退出还是抛异常,都能安全释放。不复杂但容易忽略。
以上就是C++如何在异常处理中使用智能指针管理资源的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号