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
创建数组后自动管理生命周期,超出作用域时自动调用
delete[]
支持下标访问(
ptr[i]
),但不提供
get()
以外的指针运算操作
示例代码:
#include #includeint main() {std::unique_ptr arr = std::make_unique(5);
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 #includeint main() {std::shared_ptr arr(new int[5], [](int* p) {delete[] p;});
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
代替裸数组+智能指针组合。
基本上就这些。关键是记住:unique_ptr有内置数组支持,shared_ptr需要手动加删除器,而vector通常是更好的选择。
以上就是C++如何使用智能指针管理数组对象的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1475860.html
微信扫一扫
支付宝扫一扫