c++智能指针中unique_ptr原生支持数组管理,而shared_ptr需要自定义删除器。1. unique_ptr通过指定数组类型(如int[])实现数组管理,自动调用delete[]释放内存,推荐使用make_unique方式创建;2. shared_ptr需手动指定删除器(如lambda表达式或函数模板),以确保调用delete[];3. 实际开发中更推荐优先使用std::vector或std::array等容器代替裸数组,因其具备更好的安全性和易用性。

C++智能指针确实可以用来管理数组,但并不是所有类型的智能指针都“默认”支持数组管理。其中
unique_ptr和
shared_ptr对数组的支持方式也略有不同。

unique_ptr
原生支持数组管理
unique_ptr是可以直接用于数组的,因为它有针对数组类型的特化版本。使用时只需在类型后面加上
[],就像用
new[]分配数组一样:

std::unique_ptr<int[]> arr(new int[10]);
这样声明后,
arr会自动调用
delete[]来释放内存,而不是普通的
delete,避免了未定义行为。
立即学习“C++免费学习笔记(深入)”;
常见用法:

- 初始化方式要明确指定数组类型(
int[]
) - 访问元素使用
operator[]
- 不支持拷贝构造和赋值,只能移动(move)
例如:
std::unique_ptr<int[]> createArray() {
return std::make_unique<int[]>(5); // C++14 起支持 make_unique 数组
}注意点:
- 如果你不小心用了
unique_ptr<int>
然后传入new int[10]
,那就会导致内存泄漏或崩溃,因为析构时会调用delete
而不是delete[]
。 - 使用
make_unique<int[]>(size)
是更推荐的方式,它安全且简洁。
shared_ptr
管理数组需要自定义删除器
相比之下,
shared_ptr并没有为数组提供专门的特化版本。如果你直接写:
std::shared_ptr<int> ptr(new int[10]);
这会导致错误,因为默认情况下它会在析构时调用
delete,而你应该使用
delete[]。
解决办法是手动指定删除器:
std::shared_ptr<int> ptr(new int[10], [](int* p) { delete[] p; });或者封装成一个函数模板:
template<typename T> using array_deleter = std::default_delete<T[]>; std::shared_ptr<int> ptr(new int[10], array_deleter<int>());
适用场景:
- 需要多个智能指针共享同一个数组的所有权
- 想避免手动管理生命周期,又需要动态数组
- 可以配合
std::vector
替代方案考虑(如果不需要共享所有权)
为什么 unique_ptr
支持数组,而 shared_ptr
没有原生支持?
这是设计上的取舍:
unique_ptr
更强调轻量、高效、资源专有性,因此标准库提供了数组特化来满足一些底层需求;shared_ptr
的设计初衷是通用性强,而数组管理相对较少被用于共享所有权的场景,所以没做专门支持;- 同时,C++ 推荐优先使用容器如
std::vector
或std::array
,它们已经很好地解决了大多数数组问题。
实际建议:优先考虑容器代替裸数组
虽然智能指针能管理数组,但在现代 C++ 中,更推荐使用标准容器:
std::vector
动态数组std::array
固定大小数组
它们自带内存管理、边界检查、迭代器等特性,比裸数组 + 智能指针组合更安全、易用。
比如:
auto vec = std::make_shared<std::vector<int>>(10);
这样就不需要自己处理数组的释放逻辑了。
基本上就这些。如果你确实需要管理裸数组,记住
unique_ptr直接支持,
shared_ptr需要加删除器;不过多数时候,用容器就够了。










