C++内存管理需结合new/delete与智能指针。new分配堆内存,delete释放,须配对使用以防泄漏或未定义行为;异常可能中断释放流程。std::unique_ptr独占资源,离开作用域自动释放,支持所有权转移,不支持拷贝。std::shared_ptr通过引用计数共享资源,最后一个指针销毁时释放内存,建议用std::make_shared创建。循环引用导致内存泄漏,可用std::weak_ptr打破,weak_ptr不增引用计数,通过lock检查对象是否存在。优先使用智能指针替代裸指针,遵循RAII原则,确保资源安全自动管理。

C++中的内存管理是程序稳定性和性能的关键。手动管理内存容易引发泄漏、重复释放或悬空指针等问题,因此现代C++推荐结合new/delete与智能指针来更安全地管理资源。
new和delete是C++中用于动态分配和释放堆内存的操作符。
使用new在堆上创建对象,返回指向该对象的指针;delete释放由new分配的单个对象,delete[]用于数组。
常见写法:
立即学习“C++免费学习笔记(深入)”;
int* p = new int(10); delete p;int* arr = new int[5]; delete[] arr;new必须配对delete,否则造成内存泄漏。delete同一指针,会导致未定义行为。delete未被执行,这是手动管理的风险所在。std::unique_ptr是一种轻量级智能指针,提供对动态对象的独占所有权。
unique_ptr拥有该资源。delete,无需手动释放。std::move)。示例:
<pre class="brush:php;toolbar:false;">std::unique_ptr<int> ptr(new int(20));
// 或更好写法:std::make_unique<int>(20) (C++14起)
{
std::unique_ptr<int> ptr2 = std::move(ptr); // 所有权转移
} // ptr2 离开作用域,内存自动释放
std::shared_ptr实现引用计数的智能指针,允许多个指针共享同一块内存。
shared_ptr指向对象,引用计数加1。shared_ptr销毁时,自动释放内存。示例:
<pre class="brush:php;toolbar:false;">auto sp1 = std::make_shared<int>(42);
{
auto sp2 = sp1; // 引用计数变为2
} // sp2销毁,计数减为1
// sp1仍有效
std::make_shared创建,效率更高且更安全。
当两个shared_ptr互相持有对方时,引用计数无法归零,导致内存泄漏。
std::weak_ptr打破循环引用。weak_ptr不增加引用计数,仅观察对象是否存在。使用方式:
<pre class="brush:php;toolbar:false;">std::weak_ptr<int> wp;
{
auto sp = std::make_shared<int>(100);
wp = sp;
if (auto locked = wp.lock()) {
// 对象还存在
*locked += 10;
}
} // sp释放后,wp不再能lock成功
基本上就这些。合理使用new/delete并优先采用智能指针,尤其是unique_ptr和shared_ptr,能大幅降低内存问题风险。不复杂但容易忽略的是:养成不用裸指针的习惯,让RAII机制替你管理资源。
以上就是C++如何管理内存_C++ new/delete与智能指针(shared_ptr, unique_ptr)的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号