C++中智能指针通过RAII管理内存,避免泄漏。1. unique_ptr独占所有权,不可复制但可移动,离开作用域自动释放;2. shared_ptr共享所有权,引用计数控制生命周期,用make_shared创建;3. weak_ptr不增加引用计数,防循环引用,需lock()访问对象。优先使用make_unique和make_shared,避免裸指针。

在C++中,智能指针是用于自动管理动态内存的工具,能有效避免内存泄漏和悬空指针问题。它们通过RAII(资源获取即初始化)机制,在对象生命周期结束时自动释放所管理的资源。C++标准库提供了几种主要的智能指针类型,每种适用于不同场景。
std::unique_ptr — 独占所有权的智能指针
特点:同一时间只能有一个unique_ptr拥有对资源的控制权,不能复制,但可以移动。
适用于:确保某个资源只被一个所有者管理的场景。
常用操作:
立即学习“C++免费学习笔记(深入)”;
使用std::make_unique创建(C++14起支持) 离开作用域时自动释放内存 可通过std::move转移所有权
示例:
#include
std::unique_ptr ptr = std::make_unique(42);
*ptr = 100; // 使用指针
// 离开作用域时自动释放
std::shared_ptr — 共享所有权的智能指针
特点:多个shared_ptr可以共享同一个对象,内部使用引用计数,当最后一个shared_ptr销毁时,资源自动释放。
适用于:需要多个部分共享同一个对象的场景。
常用操作:
立即学习“C++免费学习笔记(深入)”;
使用std::make_shared高效创建 拷贝shared_ptr会增加引用计数 可用use_count()查看引用数量
示例:
#include
std::shared_ptr ptr1 = std::make_shared(50);
std::shared_ptr ptr2 = ptr1; // 引用计数变为2
// 当ptr1和ptr2都离开作用域后,内存才释放
std::weak_ptr — 非拥有型指针,配合shared_ptr使用
特点:不增加引用计数,用于观察shared_ptr管理的对象,防止循环引用。
适用于:解决shared_ptr之间相互引用导致内存无法释放的问题。
使用方法:
从shared_ptr构造 调用lock()获取临时shared_ptr来访问对象 若对象已释放,lock()返回空shared_ptr
示例:
std::shared_ptr shared = std::make_shared(30);
std::weak_ptr weak = shared;
if (auto locked = weak.lock()) {
std::cout << *locked << std::endl;
}
基本上就这些。合理选择智能指针类型,能大幅提升代码安全性和可维护性。注意避免循环引用,优先使用make_shared和make_unique创建,减少异常风险。不复杂但容易忽略细节。
以上就是c++++怎么使用智能指针_c++智能指针类型与用法说明的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1482221.html
微信扫一扫
支付宝扫一扫