智能指针之shared_ptr基本概述

1.shared_ptr允许有多个指针指向同一个对象,unique_ptr独占所指向的对象。

2.类似于vector,智能指针也是模板。创建智能指针:

1 shared_ptr<string> p1;        //指向string的shared_ptr
2 shared_ptr<list<int>> p2;   //指向int的list的shared_ptr

使用make_shared函数分配一个对象并初始化它,make_shared函数返回一个指向此对象的shared_ptr:

//指向值为42的int的shared_ptr
shared_ptr<int> p3 = make_shared<int>(42);

//指向一个值为“999”的string
shared_ptr<string> p4 = make_shared<string>("999");
//指向一个值初始化的int,即值为0
shared_ptr<int> p5 = make_shared<int>();

3.我们可以认为每个share_ptr都有一个关联的计数器,通常称为引用计数(reference count)。无论何时我们拷贝一个shared_ptr,计数器都会递增。

例如这些都会使所关联的计数器递增

(1)当用一个shared_ptr初始化另外一个shared_ptr

(2)将它作为参数传递给另外一个函数

(3)作为函数的返回值

例如这些操作会使计数器都会递减:

(1)给share_ptr赋新的值

(2)share_ptr被销毁

(3)局部的share_ptr离开作用域

 以下通过两个例子来讲解计数的规则:

 shared_ptr<int> p = make_shared<int>(42);
 shared_ptr<int> q(p);                        //此对象现在有两个引用者,计数为2
 shared_ptr<int> r = make_shared<int>(42);   //r现在有一个计数
 r = q;                                        //r现在指向q所指向的对象了,所以第二个42被销毁,因为计数为0
                                                 //而第一个计数为3
 cout << "p所指对象的引用计数为:" << p.use_count() << endl;

 再比如下一个程序:

 1 shared_ptr<Foo> factory(T arg)
 2 {
 3     return make_shared<Foo>(arg);        //返回一个shared_ptr<Foo>
 4 }
 5 void use_factory(T arg)
 6 {
 7     shared_ptr<Foo> p = factory(arg);   //此时p的计数值为1
 8 }        //由于p是局部变量,出了这个函数,计数值先递减,然后检查计数值,发现为0,销毁p的对象,内存被释放掉
 9 shared_ptr<Foo> use_factory(T arg)
10 {
11     shared_ptr<Foo> p = factory(arg);   //此时p的计数值为1
12     return p;                            //返回了一个智能指针类,计数值加1,为2
13 }    //离开了作用域,但是指向的内存不会被释放,因为还有对象的引用计数不是0

 4.当指向的最后一个shared_ptr被销毁时,是调用析构函数来完成销毁工作的,析构函数会先递减它所指向的对象的引用计数,再检查引用计数值,如果引用计数变为0,那么shared_ptr析构函数就会销毁对象,并释放它占用的内存。

附:shared_ptr支持的一些操作:

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
智能指针是C++中用于管理动态分配的内存的一种机制。它们可以自动地在不再需要时释放内存,从而避免内存泄漏和悬挂指针的问题。 shared_ptr是一种引用计数智能指针,它可以跟踪有多少个shared_ptr指向同一个对象,并在没有引用时自动释放内存。当创建shared_ptr时,它会增加引用计数,当销毁或重置shared_ptr时,它会减少引用计数。只有当引用计数为0时,才会真正释放内存。\[1\]shared_ptr可以通过构造函数接受一个指向动态分配对象的指针来创建,也可以使用std::make_shared函数来创建。\[2\] unique_ptr是一种独占智能指针,它拥有对动态分配对象的唯一所有权。当unique_ptr被销毁时,它会自动释放内存。unique_ptr不能被复制,但可以通过std::move函数进行转移所有权。\[3\]unique_ptr可以通过构造函数接受一个指向动态分配对象的指针来创建。 weak_ptr是一种弱引用智能指针,它指向由shared_ptr管理的对象,但不会增加引用计数。weak_ptr可以用于解决shared_ptr的循环引用问题,因为它不会导致对象无法释放。\[1\]weak_ptr可以通过shared_ptr的构造函数来创建。 auto_ptr是C++11之前的一种智能指针,它类似于unique_ptr,但有一些限制和问题。auto_ptr在复制时会转移所有权,这可能导致悬挂指针的问题。因此,auto_ptr已经被unique_ptr取代,不推荐使用。 总结来说,shared_ptr是引用计数智能指针,unique_ptr是独占智能指针,weak_ptr是弱引用智能指针,而auto_ptr是已经过时的智能指针。它们各自有不同的用途和特点,可以根据具体的需求选择使用。 #### 引用[.reference_title] - *1* *2* *3* [C++11 解决内存泄露问题的智能指针shared_ptr、unique_ptr、weak_ptr](https://blog.csdn.net/weixin_44120785/article/details/128714630)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值