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 基本用法与注意事项
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未被执行,这是手动管理的风险所在。
unique_ptr:独占式资源管理
std::unique_ptr是一种轻量级智能指针,提供对动态对象的独占所有权。
- 同一时间只有一个
unique_ptr拥有该资源。 - 离开作用域时自动调用
delete,无需手动释放。 - 不支持拷贝,但可转移所有权(通过
std::move)。
示例:
std::unique_ptrptr(new int(20)); // 或更好写法:std::make_unique (20) (C++14起) { std::unique_ptr ptr2 = std::move(ptr); // 所有权转移 } // ptr2 离开作用域,内存自动释放
shared_ptr:共享式资源管理
std::shared_ptr实现引用计数的智能指针,允许多个指针共享同一块内存。
- 每增加一个
shared_ptr指向对象,引用计数加1。 - 当最后一个
shared_ptr销毁时,自动释放内存。 - 适合多个模块需要访问同一资源的场景。
示例:
auto sp1 = std::make_shared建议:优先使用(42); { auto sp2 = sp1; // 引用计数变为2 } // sp2销毁,计数减为1 // sp1仍有效
std::make_shared创建,效率更高且更安全。
避免循环引用:weak_ptr 的作用
当两个shared_ptr互相持有对方时,引用计数无法归零,导致内存泄漏。
- 使用
std::weak_ptr打破循环引用。 -
weak_ptr不增加引用计数,仅观察对象是否存在。
使用方式:
std::weak_ptrwp; { auto sp = std::make_shared (100); wp = sp; if (auto locked = wp.lock()) { // 对象还存在 *locked += 10; } } // sp释放后,wp不再能lock成功
基本上就这些。合理使用new/delete并优先采用智能指针,尤其是unique_ptr和shared_ptr,能大幅降低内存问题风险。不复杂但容易忽略的是:养成不用裸指针的习惯,让RAII机制替你管理资源。










