unique_ptr通过模板参数T[]自动调用delete[]管理数组,shared_ptr需显式指定删除器如lambda表达式[](T* p){ delete[] p; },而vector因自动扩容、安全高效且接口丰富,通常优于智能指针管理数组。

在C++中,使用智能指针管理数组对象需要特别注意选择合适的类型。普通
std::unique_ptr和
std::shared_ptr默认调用
delete释放资源,而数组应使用
delete[]。为此,C++提供了专门的支持方式。
使用 std::unique_ptr 管理数组
std::unique_ptr支持数组的特化版本,只需在模板参数中加上
[],即可自动使用
delete[]释放内存。
- 声明格式:
std::unique_ptr<T[]>
- 创建数组后自动管理生命周期,超出作用域时自动调用
delete[]
- 支持下标访问(
ptr[i]
),但不提供get()
以外的指针运算操作
示例代码:
#include <memory>
#include <iostream>
<p>int main() {
std::unique_ptr<int[]> arr = std::make_unique<int>(5);</p><pre class="brush:php;toolbar:false;">for (int i = 0; i < 5; ++i) {
arr[i] = i * 10;
std::cout << arr[i] << " ";
}
// 超出作用域时自动释放
return 0;}
使用 std::shared_ptr 管理数组
std::shared_ptr本身不会自动调用
delete[],必须显式指定删除器(deleter)。
立即学习“C++免费学习笔记(深入)”;
- 可通过lambda或函数对象定义删除行为
- 常用方法是传入
[](T* p){ delete[] p; } - 引用计数机制适合多处共享数组的情况
示例代码:
#include <memory>
#include <iostream>
<p>int main() {
std::shared_ptr<int> arr(new int[5], [](int* p) {
delete[] p;
});</p><pre class="brush:php;toolbar:false;">for (int i = 0; i < 5; ++i) {
arr.get()[i] = i + 1;
std::cout << arr.get()[i] << " ";
}
// 最后一个shared_ptr销毁时触发自定义删除器
return 0;}
为什么不推荐使用 std::vector?
虽然智能指针可以管理数组,但在大多数场景下,std::vector是更安全、更高效的选择。
- 自动管理容量增长
- 提供丰富的接口(size、push_back等)
- 与STL算法无缝集成
- 避免手动指定删除器的错误风险
除非有特殊需求(如与C风格API交互、性能敏感且大小固定),否则优先考虑
std::vector<T>代替裸数组+智能指针组合。
基本上就这些。关键是记住:unique_ptr有内置数组支持,shared_ptr需要手动加删除器,而vector通常是更好的选择。










