c++怎么使用shared_ptr_c++ shared_ptr智能指针详解

std::shared_ptr通过引用计数管理动态对象,使用make_shared创建并共享所有权,引用计数为0时自动释放资源;可自定义删除器处理特殊资源;需用weak_ptr打破循环引用以防内存泄漏。

c++怎么使用shared_ptr_c++ shared_ptr智能指针详解

在C++中,std::shared_ptr 是一种智能指针,用于管理动态分配的对象,实现共享所有权的机制。它通过引用计数自动追踪有多少个 shared_ptr 指向同一个对象,当最后一个指向该对象的 shared_ptr 被销毁或重置时,对象会自动被删除,从而避免内存泄漏。

1. 包含头文件和基本用法

要使用 shared_ptr,需要包含 头文件:

#include
#include iostream>

创建一个 shared_ptr 的常用方式是使用 std::make_shared,这是推荐的做法,因为它更高效且异常安全:

auto ptr = std::make_shared(42);
std::cout

2. 共享所有权与引用计数

多个 shared_ptr 可以指向同一个对象,每增加一个引用,引用计数加1;减少一个则减1。

立即学习“C++免费学习笔记(深入)”;

auto p1 = std::make_shared(100);
{
    auto p2 = p1; // 引用计数变为 2
    std::cout } // p2 离开作用域,引用计数减为 1
std::cout

use_count() 返回当前对象的引用数量,仅用于调试,不要依赖它做逻辑判断。

3. 自定义删除器

有时需要自定义资源释放逻辑,比如关闭文件、释放非new分配的内存等,可以传入删除器:

void close_file(FILE* fp) {
    if (fp) fclose(fp);
}

auto file_ptr = std::shared_ptr(fopen(“test.txt”, “w”), close_file);
if (file_ptr) {
    fprintf(file_ptr.get(), “Hello, shared_ptr!n”);
} // 离开作用域时自动调用 close_file

删除器可以是函数、lambda 或仿函数。

4. 注意循环引用问题

当两个对象通过 shared_ptr 相互持有对方时,引用计数永远不为0,导致内存泄漏:

struct Node;
using NodePtr = std::shared_ptr;

struct Node {
    NodePtr parent;
    NodePtr child;
    ~Node() { std::cout };

auto a = std::make_shared();
auto b = std::make_shared();
a->child = b;
b->parent = a; // 循环引用,无法释放

解决方法是使用 std::weak_ptr 打破循环:

struct Node {
    std::weak_ptr parent; // 不增加引用计数
    NodePtr child;
    ~Node() { std::cout };

这样当外部引用消失时,对象能被正确释放。

基本上就这些。合理使用 shared_ptr 能显著提升代码安全性,但要注意避免循环引用,优先使用 make_shared 创建实例。

以上就是c++++怎么使用shared_ptr_c++ shared_ptr智能指针详解的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1481702.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 05:43:41
下一篇 2025年12月11日 14:26:35

相关推荐

发表回复

登录后才能评论
关注微信